Linux
## 什么是Linux
1. Linux 是一款类Unix的操作系统。
2. Linux 使用非常广泛,从 Android 到 云计算无所不在。
## Linux 命令
1. 适合远程管理服务器
2. 资源占用低
## Linux命令语法
命令 -选项 参数1 参数2 参数3
### 列文件夹的内容
ls -al /
-a 显示全部内容
-l 显示长格式
/ 参数,目标文件夹
### 如何查询命令的帮助
man 命令, 使用q按键退出手册
命令 --help
### Linux 的文件系统
/ 根目录
|- etc <-
|- usr
|- home
| |- soft01 用户的主目录
|- root root用户的主目录
|- var
...
当前工作目录
pwd 显示当前的工作目录
cd 目标文件夹 改变当前工作目录
### 文件操作管理命令
1. 创建文件夹
cd 返回用户的主目录
mkdir 文件夹名 在当前文件夹中创建文件夹
mkdir 绝对路径名 在指定位置创建文件夹
cd
mkdir demo
mkdir /home/soft01/abc
2. 创建文件
touch 文件名
3. 修改时间
touch 已经存在文件名/文件夹
ls -l
4. 复制文件/文件夹命令
cp 源文件/文件夹 目标文件/文件夹
源文件/文件夹必须存在! 不存在就会报错误.
目标文件/文件夹不存在就是创建新的文件/文件夹
如果目标文件/文件夹是存在, 文件则覆盖,文件夹
就是复制到文件夹中.
cp /etc/passwd passwd.bak 改名复制
cp /etc/passwd test 不改名复制
cp /etc/passwd test/pwd 改名复制
cp /etc/passwd . 复制到当前目录
复制文件夹必须使用 -r 进行递归复制
cp -r test abc abc不存在,将test复制为abc
mkdir demo
cp -r test demo 将文件夹复制到demo文件夹中
### 改名或者移动
mv 源 目标
源:必须存在
目标:如果不存在,就是改名 目标如果存在就是移动
### 删除命令
rm -rf 文件 文件夹 文件夹....
rm -rf passwd.bak passws t
## sftp
- ftp 占用21端口, 文件传输协议, 用于在客户端和服务器之间传输文件, 采用明码传输文件数据, 不安全.
- sftp 是 SSH 协议提供的功能, 与SSH占用一样的22端口, 也可以在客户端和服务器之间传输文件, 采用加密传输, 安全可靠.
sftp 命令
lls 查看本地目录内容
lcd 切换本地文件夹
lpwd 查看本地文件夹位置
ls 查看远程目录内容
cd 切换远程目录
pwd 查看远程文件夹位置
put 上载文件到远程文件夹
get 下载文件到本地文件夹
## 打包命令
打包:
tar -czvf 文件.tar.gz 文件 文件夹 ...
-c 创建包
-z 将包进行gzip压缩, 建议文件名 .tar.gz
-v 查看打包过程
-f 指定打包以后的文件名: .tar 结尾
释放:
tar -xzvf 文件.tar.gz
-x 释放, x和c不能共存
-z 在.gz为结尾时候使用
## vi 可视化编辑器
- 基于终端窗口的可视化编辑器
- 不能鼠标
- vi 的作者是Java创始人之一
- 开源的vim克隆了vi
## 利用wget下载
语法:
wget http://download.oracle.com/otn-pub/java/jdk/8u171-b11/512cd62ec5174c3487ac17c61aaa89e8/jdk-8u171-linux-x64.tar.gz
## 配置Java环境变量
export JAVA_HOME=/usr/local/java/jdk1.8.0_144
export PATH=/usr/local/java/jdk1.8.0_144/bin:$PATH
export CLASSPATH=.
cd
javac -version
javac HelloWorld.java
java HelloWorld
### PATH
操作系统可执行命令的搜索路径, 操作系统在执行命令时候, 会将用命令名依次搜索PATH变量中的系列路径, 如果搜索到相同名字的程序(命令)就执行这个命令, 否则没有搜索到则报错误: 命名没有找到!!
## profile
Linux 操作系统初始化脚本 profile
初始化顺序:
查看profile
ls /etc|grep profile
cat /etc/profile //查看文本文件内容
more /etc/profile //分页查看文本文件内容
修改
$su //切换用户身份, 如果不加参数则切换到管理员 需要输入密码
#cd /etc
#cp profile profile.2018.4.28
#vim profile
修改内容:
export PATH=/bin:/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin:/root/bin
export JAVA_HOME=/usr/local/java/jdk1.8.0_144
export PATH=/usr/local/java/jdk1.8.0_144/bin:$PATH
export CLASSPATH=.
测试:
cat profile
source profile
javac -version
which javac
which java
which tar
echo $PATH
重新启动服务器
reboot
## 安装Tomcat
### yum安装
1. 安装
yum -y install tomcat
2. 启动
systemctl start tomcat.service
3. 关闭
systemctl stop tomcat.service
4. 重新启动
systemctl restart tomcat.service
5. 设置开机自动启动
systemctl enable tomcat.service
6. 下载Tomcat将ROOT复制到 /usr/share/tomcat/webapps
> 下载地址从 Tomcat 网站获得
wget http://tomcat.apache.org....apache-tomcat-7.0.67.zip
yum -y install unzip
unzip apache-tomcat-7.0.67.zip
cd apache-tomcat-7.0.67/webapps
cp -r ROOT /usr/share/tomcat/webapps
## 下载安装Tomcat
1. 下载Tomcat将ROOT复制到 /usr/share/tomcat/webapps
> 下载地址从 Tomcat 网站获得
wget http://doc.tedu.cn/tomcat/apache-tomcat-7.0.67.zip
unzip apache-tomcat-7.0.67.zip
mv apache-tomcat-7.0.67 /usr/local
2. 启动tomcat
cd /usr/local/apache-tomcat-7.0.67/bin
chmod +x *.sh //为所有.sh文件增加执行权限
./startup.sh //启动tomcat
3. 检查tomcat
ps -A|grep java
4. 关闭tomcat
./shutdown.sh
5. 配置环境变量(可选):
export CATALINA_HOME=/usr/local/apache-tomcat-7.0.67
export PATH=$CATALINA_HOME/bin:$PATH
6. 开放防火墙端口
firewall-cmd --permanent --add-port=8080/tcp
firewall-cmd --reload
7. 客户端测试:
http://192.168.17.70:8080
## 远程登录
## 开启阿里云的端口
1. 进入服务器安全管理界面
管理控制台 -> 云服务器 ECS -> 实例 -> 管理 -> 本实例安全组 -> 配置规则
2. 添加规则
## 安装MySQL
MySQL 分支为两个软件:
1. Oralce MySQL
2. MariaDB
简单理解 MariaDB 就是MySQL
### yum 安装
1. 安装
yum -y install mariadb-server mariadb
2. 启动
systemctl start mariadb.service
3. 检查
ps -A|grep mysql
4. 关闭与重启
systemctl stop mariadb.service
systemctl restart mariadb.service
## MySQL 编码设置
1. 检查
show variables like 'char%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
2. 修改配置文件, 设置数据库的默认编码
vim /etc/my.cnf
文件中添加:
[mysqld]
character-ser-server=utf8
[mysql]
default-character-set=utf8
3. 重启MySQL(mariadb)
systemctl restart mariadb.service
4. 检查
show variables like 'char%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
## 部署Web项目到服务器
原理:
### 1. 迁移数据库
1. 源服务器上导出现有数据库到SQL
mysqldump -uroot -p tedu_store > tedu_store.sql
> `>` 符号是"输出重定向", 其目的是将第一个mysqldump命令的结果送到一个文件tedu_store.sql 中.
2. sftp 将tedu_store.sql 传输到目标数据库服务器
> windows版本的putty软件带来了 psftp, 可向服务器传输数据
3. 在目标服务器的MySQL控制台执行
create database tedu_store;
use tedu_store
source tedu_store.sql
### 2. 部署Java Web 应用到目标Tomcat服务器
1. 利用开发工具将项目导出war文件
- 导出前将数据库的配置信息改写目标的数据库配置信息
2. 利用sftp将war文件传输到目标服务器
3. 在目标服务器上利用cp命令将war文件部署到Tomcat中
cp TeduStore.war /usr/local/apach-tomcat-7.0.67/webapps
4. 重写启动Tomcat服务器
5. 如果有错误请查看日志文件
cat /usr/local/apach-tomcat-7.0.67/logs/catalina.out
6. 测试
http://生产环境ip:8080/TeduStore/user/showLogin.jsp
### 检查技巧
1. 检查MySQL, 确认数据库已经成功迁移, 要检查:数据库\表\数据.
2. 检查Tomcat, 确认db.properties是否正确配置了数据库参数
3. 检查Tomcat是否成功启动.
- ps -A|grep java
4. 检查Tomcat日志:
- /usr/local/apache-tomcat-7.0.67/logs
5. 在防火墙上开启 8080 端口
### 远程访问MySQL
连接原理为:
数据库服务器端
1. 创建一个用户专门用于远程访问
//创建用户并且授权的命令
GRANT ALL ON 数据库名.* TO 用户名@客户端的ip/域名
IDENTIFIED BY "密码";
例如:
GRANT ALL ON tedu_store.* TO [email protected]
IDENTIFIED BY "tedu123";
> 客户端的ip是 192.168.17.12, 用户名是tedu 密码是tedu123
2. 服务器防火墙开放 3306 端口(如果需要的话)
firewall-cmd --permanent --add-port=3306/tcp
firewall-cmd --reload
客户端
1. 利用mysql 客户端连接到服务器端检查是否能够连接
mysql -h192.168.17.70 -utedu -ptedu123
> MySQL 服务器的IP是192.168.17.70
2. 更新 Tomcat中的应用程序参数db.properties 连接到远程的数据库:
url=jdbc:mysql://47.105.48.39:3306/tedu_store?useUnicode=true&characterEncoding=utf8
driver=com.mysql.jdbc.Driver
user=tedu
password=tedu123
3. 测试...
## 文件权限
Linux 限定用户可以读写那些文件.
查看文件的权限:
ls -l 以长格式显示文件列表, 包含权限信息
ll CentOS Linux提供的简写命令
文件权限:
利用chmod设置文件的权限:
### 文件的执行权限
Linux中的可执行文件(命令), 必须满足两个条件才行:
1. 这个文件本身是可以执行的文件
- 一种是2进制的程序文件
- shell脚本文件(.sh), 是一种文本文件, 每行都是可以执行命令
2. 这个文件必须有执行权限
满足如上两个条件才能执行.
### shell 脚本
shell脚本文件(.sh), 是一种文本文件, 每行都是可以执行命令
shell用于批量执行操作系统命令, 可以实现运维自动化
案例: 自动备份MySQL数据库, 并且传输到远程的服务器
## 输出重定向
## Nginx
1. tar
创建一个新的tar文件
$ tar cvf archive_name.tar dirname/
解压tar文件
$ tar xvf archive_name.tar
查看tar文件
$ tar tvf archive_name.tar
2. grep
在文件中查找字符串(不区分大小写)
$ grep -i "the" demo_file
输出成功匹配的行,以及该行之后的三行
$ grep -A 3 -i "example" demo_text
在一个文件夹中递归查询包含指定字符串的文件
$ grep -r "ramesh" *
3. find
查找指定文件名的文件(不区分大小写)
$ find -iname "MyProgram.c"
对找到的文件执行某个命令
$ find -iname "MyProgram.c" -exec md5sum {} \;
查找home目录下的所有空文件
$ find ~ -empty
4. ssh
登录到远程主机
$ ssh -l jsmith remotehost.example.com
调试ssh客户端
$ ssh -v -l jsmith remotehost.example.com
显示ssh客户端版本
$ ssh -V
5. sed
当你将Dos系统中的文件复制到Unix/Linux后,这个文件每行都会以\r\n结尾,sed可以轻易将其转换为Unix格式的文件,使用\n结尾的文件
$ sed 's/.$//' filename
反转文件内容并输出
$ sed -n '1!G; h; p' filename
为非空行添加行号
$ sed '/./=' thegeekstuff.txt | sed 'N; s/\n/ /'
6. awk
删除重复行
$ awk '!($0 in array) { array[$0]; print}' temp
打印/etc/passwd中所有包含同样的uid和gid的行
$ awk -F ':' '$3=$4' /etc/passwd
打印文件中的指定部分的字段
$ awk '{print $2,$5;}' employee.txt
7. vim
打开文件并跳到第10行
$ vim +10 filename.txt
打开文件跳到第一个匹配的行
$ vim +/search-term filename.txt
以只读模式打开文件
$ vim -R /etc/passwd
8. diff
比较的时候忽略空白符
$ diff -w name_list.txt name_list_new.txt
9. sort
以升序对文件内容排序
$ sort names.txt
以降序对文件内容排序
$ sort -r names.txt
以第三个字段对/etc/passwd的内容排序
$ sort -t: -k 3n /etc/passwd | more
10. export
输出跟字符串oracle匹配的环境变量
$ export | grep ORCALE
declare -x ORACLE_BASE="/u01/app/oracle"
declare -x ORACLE_HOME="/u01/app/oracle/product/10.2.0"
declare -x ORACLE_SID="med"
declare -x ORACLE_TERM="xterm"
设置全局环境变量
$ export ORACLE_HOME=/u01/app/oracle/product/10.2.0
11. xargs
将所有图片文件拷贝到外部驱动器
$ ls *.jpg | xargs -n1 -i cp {} /external-hard-drive/directory
将系统中所有jpd文件压缩打包
$ find / -name *.jpg -type f -print | xargs tar -cvzf images.tar.gz
下载文件中列出的所有url对应的页面
$ cat url-list.txt | xargs wget –c
12. ls
以易读的方式显示文件大小(显示为MB,GB...)
$ ls -lh
-rw-r----- 1 ramesh team-dev 8.9M Jun 12 15:27 arch-linux.txt.gz
以最后修改时间升序列出文件
$ ls -ltr
在文件名后面显示文件类型
$ ls -F
13. pwd
输出当前工作目录
14. cd
cd -
可以在最近工作的两个目录间切换
使用shopt -s cdspell
可以设置自动对cd命令进行拼写检查
15. gzip
创建一个*.gz的压缩文件
$ gzip test.txt
解压*.gz文件
$ gzip -d test.txt.gz
显示压缩的比率
$ gzip -l *.gz
compressed uncompressed ratio uncompressed_name
23709 97975 75.8% asp-patch-rpms.txt
16. bzip2
创建*.bz2压缩文件
$ bzip2 test.txt
解压*.bz2文件
bzip2 -d test.txt.bz2
17. uzip
解压*.zip文件
$ unzip test.zip
查看*.zip文件的内容
$ unzip -l jasper.zip
Archive: jasper.zip
Length Date Time Name
-------- ---- ---- ----
40995 11-30-98 23:50 META-INF/MANIFEST.MF
32169 08-25-98 21:07 classes_
15964 08-25-98 21:07 classes_names
10542 08-25-98 21:07 classes_ncomp
18. shutdown
关闭系统并立即关机
$ shutdown -h now
10分钟后关机
$ shutdown -h +10
重启
$ shutdown -r now
重启期间强制进行系统检查
$ shutdown -Fr now
19. ftp
ftp命令和sftp命令的用法基本相似连接ftp服务器并下载多个文件
$ ftp IP/hostname
ftp> mget *.html
显示远程主机上文件列表
ftp> mls *.html -
/ftptest/features.html
/ftptest/index.html
/ftptest/othertools.html
/ftptest/samplereport.html
/ftptest/usage.html
20. crontab
查看某个用户的crontab入口
$ crontab -u john -l
设置一个每十分钟执行一次的计划任务
*/10 * * * * /home/ramesh/check-disk-space
21. service
service命令用于运行System V init脚本,这些脚本一般位于/etc/init.d文件下,这个命令可以直接运行这个文件夹里面的脚本,而不用加上路径
查看服务状态
$ service ssh status
查看所有服务状态
$ service --status-all
重启服务
$ service ssh restart
22. ps
ps命令用于显示正在运行中的进程的信息,ps命令有很多选项,这里只列出了几个
查看当前正在运行的所有进程
$ ps -ef | more
以树状结构显示当前正在运行的进程,H选项表示显示进程的层次结构
$ ps -efH | more
23. free
这个命令用于显示系统当前内存的使用情况,包括已用内存、可用内存和交换内存的情况
默认情况下free会以字节为单位输出内存的使用量
$ free
total used free shared buffers cached
Mem: 3566408 1580220 1986188 0 203988 902960
-/+ buffers/cache: 473272 3093136
Swap: 4000176 0 4000176
如果你想以其他单位输出内存的使用量,需要加一个选项,-g为GB,-m为MB,-k为KB,-b为字节
$ free -g
total used free shared buffers cached
Mem: 3 1 1 0 0 0
-/+ buffers/cache: 0 2
Swap: 3 0 3
如果你想查看所有内存的汇总,请使用-t选项,使用这个选项会在输出中加一个汇总行
ramesh@ramesh-laptop:~$ free -t
total used free shared buffers cached
Mem: 3566408 1592148 1974260 0 204260 912556
-/+ buffers/cache: 475332 3091076
Swap: 4000176 0 4000176
Total: 7566584 1592148 5974436
24. top
top命令会显示当前系统中占用资源最多的一些进程(默认以CPU占用率排序)如果你想改变排序方式,可以在结果列表中点击O(大写字母O)会显示所有可用于排序的列,这个时候你就可以选择你想排序的列
Current Sort Field: P for window 1:Def
Select sort field via field letter, type any other key to return
a: PID = Process Id v: nDRT = Dirty Pages count
d: UID = User Id y: WCHAN = Sleeping in Function
e: USER = User Name z: Flags = Task Flags
........
如果只想显示某个特定用户的进程,可以使用-u选项
$ top -u oracle
25. df
显示文件系统的磁盘使用情况,默认情况下df -k
将以字节为单位输出磁盘的使用量
$ df -k
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/sda1 29530400 3233104 24797232 12% /
/dev/sda2 120367992 50171596 64082060 44% /home
使用-h选项可以以更符合阅读习惯的方式显示磁盘使用量
$ df -h
Filesystem Size Used Avail Capacity iused ifree %iused Mounted on
/dev/disk0s2 232Gi 84Gi 148Gi 37% 21998562 38864868 36% /
devfs 187Ki 187Ki 0Bi 100% 648 0 100% /dev
map -hosts 0Bi 0Bi 0Bi 100% 0 0 100% /net
map auto_home 0Bi 0Bi 0Bi 100% 0 0 100% /home
/dev/disk0s4 466Gi 45Gi 421Gi 10% 112774 440997174 0% /Volumes/BOOTCAMP
//[email protected]/public 2.7Ti 1.3Ti 1.4Ti 48% 0 18446744073709551615 0% /Volumes/public
使用-T选项显示文件系统类型
$ df -T
Filesystem Type 1K-blocks Used Available Use% Mounted on
/dev/sda1 ext4 29530400 3233120 24797216 12% /
/dev/sda2 ext4 120367992 50171596 64082060 44% /home
26. kill
kill用于终止一个进程。一般我们会先用ps -ef
查找某个进程得到它的进程号,然后再使用kill -9 进程号
终止该进程。你还可以使用killall、pkill、xkill来终止进程
$ ps -ef | grep vim
ramesh 7243 7222 9 22:43 pts/2 00:00:00 vim
$ kill -9 7243
27. rm
删除文件前先确认
$ rm -i filename.txt
在文件名中使用shell的元字符会非常有用。删除文件前先打印文件名并进行确认
$ rm -i file*
递归删除文件夹下所有文件,并删除该文件夹
$ rm -r example
28. cp
拷贝文件1到文件2,并保持文件的权限、属主和时间戳
$ cp -p file1 file2
拷贝file1到file2,如果file2存在会提示是否覆盖
$ cp -i file1 file2
29. mv
将文件名file1重命名为file2,如果file2存在则提示是否覆盖
$ mv -i file1 file2
注意如果使用-f选项则不会进行提示
-v会输出重命名的过程,当文件名中包含通配符时,这个选项会非常方便
$ mv -v file1 file2
30. cat
你可以一次查看多个文件的内容,下面的命令会先打印file1的内容,然后打印file2的内容
$ cat file1 file2
-n命令可以在每行的前面加上行号
$ cat -n /etc/logrotate.conf
1 /var/log/btmp {
2 missingok
3 monthly
4 create 0660 root utmp
5 rotate 1
6 }
31. mount
如果要挂载一个文件系统,需要先创建一个目录,然后将这个文件系统挂载到这个目录上
# mkdir /u01
# mount /dev/sdb1 /u01
也可以把它添加到fstab中进行自动挂载,这样任何时候系统重启的时候,文件系统都会被加载
/dev/sdb1 /u01 ext2 defaults 0 2
32. chmod
chmod用于改变文件和目录的权限
给指定文件的属主和属组所有权限(包括读、写、执行)
$ chmod ug+rwx file.txt
删除指定文件的属组的所有权限
$ chmod g-rwx file.txt
修改目录的权限,以及递归修改目录下面所有文件和子目录的权限
$ chmod -R ug+rwx file.txt
33. chown
chown用于改变文件属主和属组
同时将某个文件的属主改为oracle,属组改为db
$ chown oracle:dba dbora.sh
使用-R选项对目录和目录下的文件进行递归修改
$ chown -R oracle:dba /home/oracle
34. passwd
passwd用于在命令行修改密码,使用这个命令会要求你先输入旧密码,然后输入新密码
$ passwd
超级用户可以用这个命令修改其他用户的密码,这个时候不需要输入用户的密码
# passwd USERNAME
passwd还可以删除某个用户的密码,这个命令只有root用户才能操作,删除密码后,这个用户不需要输入密码就可以登录到系统
# passwd -d USERNAME
35. mkdir
在home目录下创建一个名为temp的目录
$ mkdir ~/temp
使用-p选项可以创建一个路径上所有不存在的目录
$ mkdir -p dir1/dir2/dir3/dir4/
36. ifconfig
ifconfig用于查看和配置Linux系统的网络接口
查看所有网络接口及其状态
$ ifconfig -a
使用up和down命令启动或停止某个接口
$ ifconfig eth0 up
$ ifconfig eth0 down
37. uname
uname可以显示一些重要的系统信息,例如内核名称、主机名、内核版本号、处理器类型之类的信息
$ uname -a
Linux john-laptop 2.6.32-24-generic #41-Ubuntu SMP Thu Aug 19 01:12:52 UTC 2010 i686 GNU/Linux
38. whereis
当你不知道某个命令的位置时可以使用whereis命令,下面使用whereis查找ls的位置
$ whereis ls
ls: /bin/ls /usr/share/man/man1/ls.1.gz /usr/share/man/man1p/ls.1p.gz
当你想查找某个可执行程序的位置,但这个程序又不在whereis的默认目录下,你可以使用-B选项,并指定目录作为这个选项的参数。下面的命令在/tmp目录下查找lsmk命令
$ whereis -u -B /tmp -f lsmk
lsmk: /tmp/lsmk
39. whatis
wathis显示某个命令的描述信息
$ whatis ls
ls (1) - list directory contents
$ whatis ifconfig
ifconfig (8) - configure a network interface
40. locate
locate命名可以显示某个指定文件(或一组文件)的路径,它会使用由updatedb创建的数据库
下面的命令会显示系统中所有包含crontab字符串的文件
$ locate crontab
/etc/anacrontab
/etc/crontab
/usr/bin/crontab
/usr/share/doc/cron/examples/crontab2english.pl.gz
/usr/share/man/man1/crontab.1.gz
/usr/share/man/man5/anacrontab.5.gz
/usr/share/man/man5/crontab.5.gz
/usr/share/vim/vim72/syntax/crontab.vim
41. man
显示某个命令的man页面
$ man crontab
有些命令可能会有多个man页面,每个man页面对应一种命令类型
$ man SECTION-NUMBER commandname
man页面一般可以分为8种命令类型
- 用户命令
- 系统调用
- c库函数
- 设备与网络接口
- 文件格式
- 游戏与屏保
- 环境、表、宏
- 系统管理员命令和后台运行命令
例如,我们执行whatis crontab
,你可以看到crontab有两个命令类型1和5,所以我们可以通过下面的命令查看命令类型5的man页面
$ whatis crontab
crontab (1) - maintain crontab files for individual users (V3)
crontab (5) - tables for driving cron
$ man 5 crontab
42. tail
tail命令默认显示文件最后的10行文本
$ tail filename.txt
你可以使用-n选项指定要显示的行数
$ tail -n N filename.txt
你也可以使用-f选项进行实时查看,这个命令执行后会等待,如果有新行添加到文件尾部,它会继续输出新的行,在查看日志时这个选项会非常有用。你可以通过CTRL-C终止命令的执行
$ tail -f log-file
43. less
这个命名可以在不加载整个文件的前提下显示文件内容,在查看大型日志文件的时候这个命令会非常有用
$ less huge-log-file.log
当你用less命令打开某个文件时,下面两个按键会给你带来很多帮助,他们用于向前和向后滚屏
CTRL+F – forward one window
CTRL+B – backward one window
44. su
su命令用于切换用户账号,超级用户使用这个命令可以切换到任何其他用户而不用输入密码
$ su - USERNAME
用另外一个用户名执行一个命令下面的示例中用户john使用raj用户名执行ls命令,执行完后返回john的账号
[john@dev-server]$ su - raj -c 'ls'
[john@dev-server]$
用指定用户登录,并且使用指定的shell程序,而不用默认的
$ su -s 'SHELLNAME' USERNAME
45. mysql
mysql可能是Linux上使用最广泛的数据库,即使你没有在你的服务器上安装mysql,你也可以使用mysql客户端连接到远程的mysql服务器
连接一个远程数据库,需要输入密码
$ mysql -u root -p -h 192.168.1.2
连接本地数据库
$ mysql -u root -p
你也可以在命令行中输入数据库密码,只需要在-p后面加上密码作为参数,可以直接写在p后面而不用加空格
46. yum
使用yum安装apache
$ yum install httpd
更新apache
$ yum update httpd
卸载/删除apache
$ yum remove httpd
47. rpm
使用rpm安装apache
# rpm -ivh httpd-2.2.3-22.0.1.el5.i386.rpm
更新apache
# rpm -uvh httpd-2.2.3-22.0.1.el5.i386.rpm
卸载/删除apache
# rpm -ev httpd
48. ping
ping一个远程主机,只发5个数据包
$ ping -c 5 gmail.com
49. date
设置系统日期
# date -s "01/31/2010 23:59:53"
当你修改了系统时间,你需要同步硬件时间和系统时间
# hwclock –systohc
# hwclock --systohc –utc
50. wget
使用wget从网上下载软件、音乐、视频
$ wget http://prdownloads.sourceforge.net/sourceforge/nagios/nagios-3.2.1.tar.gz
下载文件并以指定的文件名保存文件
$ wget -O taglist.zip http://www.vim.org/scripts/download_script.php?src_id=7701