Linux最全最全常用命令

打印 上一主题 下一主题

主题 843|帖子 843|积分 2531

一、根本命令

1.1 关机和重启

关机
    shutdown -h now        立刻关机
    shutdown -h 5        5分钟后关机
    poweroff            立刻关机
重启
    shutdown -r now        立刻重启
    shutdown -r 5        5分钟后重启
    reboot                立刻重启
1.2 帮助命令

--help命令
  shutdown --help:
  ifconfig  --help:查看网卡信息
 
man命令(命令说明书) 
  man shutdown
  注意:man shutdown打开命令说明书之后,使用按键q退出
二、目录操作命令

2.1 目录切换 cd

命令:cd 目录
cd /        切换到根目录
cd /usr        切换到根目录下的usr目录
cd ../        切换到上一级目录 或者  cd ..
cd ~        切换到home目录
cd -        切换到前次访问的目录
2.2 目录查看 ls [-al]

命令:ls [-al]
ls                查看当前目录下的全部目录和文件
ls -a            查看当前目录下的全部目录和文件(包括隐蔽的文件)
ls -l 或 ll       列表查看当前目录下的全部目录和文件(列表查看,显示更多信息)
ls /dir            查看指定目录下的全部目录和文件   如:ls /usr
2.3 目录操作【增,删,改,查】
2.3.1 创建目录【增】 mkdir


命令:mkdir 目录
mkdir    aaa            在当前目录下创建一个名为aaa的目录
mkdir    /usr/aaa    在指定目录下创建一个名为aaa的目录
2.3.2 删除目录或文件【删】rm

命令:rm [-rf] 目录
删除文件:
rm 文件        删除当前目录下的文件
rm -f 文件    删除当前目录的的文件(不扣问)
删除目录:
rm -r aaa    递归删除当前目录下的aaa目录
rm -rf aaa    递归删除当前目录下的aaa目录(不扣问)
全部删除:
rm -rf *    将当前目录下的全部目录和文件全部删除
rm -rf /*    【自尽命令!慎用!慎用!慎用!】将根目录下的全部文件全部删除
注意:rm不仅可以删除目录,也可以删除其他文件或压缩包,为了方便各人的影象,无论删除任何目录或文件,都直接使用 rm -rf 目录/文件/压缩包
2.3.3 目录修改【改】mv 和 cp

一、重命款式录
    命令:mv 当前目录  新目录
    例如:mv aaa bbb    将目录aaa改为bbb
    注意:mv的语法不仅可以对目录进行重定名而且也可以对各种文件,压缩包等进行    重定名的操作
二、剪切目录
    命令:mv 目录名称 目录的新位置
    示例:将/usr/tmp目录下的aaa目录剪切到 /usr目录下面     mv /usr/tmp/aaa /usr
    注意:mv语法不仅可以对目录进行剪切操作,对文件和压缩包等都可实行剪切操作
三、拷贝目录
    命令:cp -r 目录名称 目录拷贝的目标位置   -r代表递归
    示例:将/usr/tmp目录下的aaa目录复制到 /usr目录下面     cp /usr/tmp/aaa  /usr
    注意:cp命令不仅可以拷贝目录还可以拷贝文件,压缩包等,拷贝文件和压缩包时不    用写-r递归
2.3.4 搜索目录【查】find

命令:find 目录 参数 文件名称
示例:find /usr/tmp -name 'a*'    查找/usr/tmp目录下的全部以a开头的目录或文件
三、文件操作命令

3.1 文件操作【增,删,改,查】

3.1.1 新建文件【增】touch

命令:touch 文件名
示例:在当前目录创建一个名为aa.txt的文件        touch  aa.txt
3.1.2 删除文件 【删】 rm

命令:rm -rf 文件名
3.1.3 修改文件【改】 vi或vim

【vi编辑器的3种模式】
    根本上vi可以分为三种状态,分别是命令模式(command mode)、插入模式(Insert mode)和底行模式(last line mode),各模式的功能区分如下:
1) 命令行模式command mode)
      控制屏幕光标的移动,字符、字或行的删除,查找,移动复制某区段及进入Insert mode下,或者到 last line mode。
      命令行模式下的常用命令:
      【1】控制光标移动:↑,↓,j
      【2】删除当前行:dd 
      【3】查找:/字符
      【4】进入编辑模式:i o a
      【5】进入底行模式::
      
2) 编辑模式(Insert mode)
      只有在Insert mode下,才可以做文字输入,按「ESC」键可回到命令行模式。
      编辑模式下常用命令:
      【1】ESC 退出编辑模式到命令行模式;
      
3) 底行模式(last line mode)
     将文件生存或退出vi,也可以设置编辑情况,如寻找字符串、列出行号……等。
     底行模式下常用命令:
     【1】退出编辑:   :q
     【2】逼迫退出:   :q!
     【3】生存并退出:  :wq
打开文件
命令:vi 文件名
示例:打开当前目录下的aa.txt文件     vi aa.txt 或者 vim aa.txt
注意:使用vi编辑器打开文件后,并不能编辑,因为此时处于命令模式,点击键盘i/a/o进入编辑模式。
编辑文件
使用vi编辑器打开文件后点击按键:i ,a或者o即可进入编辑模式。
i:在光标所在字符前开始插入
a:在光标所在字符后开始插入
o:在光标所在行的下面另起一新行插入
生存或者取消编辑
生存文件:
第一步:ESC  进入命令行模式
第二步::     进入底行模式
第三步:wq     生存并退出编辑
取消编辑:
第一步:ESC  进入命令行模式
第二步::     进入底行模式
第三步:q!     打消本次修改并退出编辑
3.1.4 文件的查看【查】

文件的查看命令:cat/more/less/tail
cat:看最后一屏
示例:使用cat查看/etc/sudo.conf文件,只能显示最后一屏内容
cat sudo.conf
more:百分比显示
示例:使用more查看/etc/sudo.conf文件,可以显示百分比,回车可以向下一行,空格可以向下一页,q可以退出查看
more sudo.conf
less:翻页查看
示例:使用less查看/etc/sudo.conf文件,可以使用键盘上的PgUp和PgDn向上    和向下翻页,q结束查看
less sudo.conf
tail:指定行数或者动态查看
示例:使用tail -10 查看/etc/sudo.conf文件的后10行,Ctrl+C结束  
tail -10 sudo.conf
3.2 权限修改

rwx:r代表可读,w代表可写,x代表该文件是一个可实行文件,假如rwx恣意位置变为-则代表不可读或不可写或不可实行文件。
示例:给aaa.txt文件权限改为可实行文件权限,aaa.txt文件的权限是-rw-------
第一位:-就代表是文件,d代表是文件夹
第一段(3位):代表拥有者的权限
第二段(3位):代表拥有者所在的组,组员的权限
第三段(最后3位):代表的是其他用户的权限
   421  421  421
-  rw-   ---     ---
  1. 命令:chmod +x aaa.txt
  2. 或者采用8421法
  3. 命令:chmod 100 aaa.txt
复制代码
四、压缩文件操作

4.1 打包和压缩

Windows的压缩文件的扩展名  .zip/.rar
linux中的打包文件:aa.tar      
linux中的压缩文件:bb.gz    
linux中打包并压缩的文件:.tar.gz
Linux中的打包文件一般是以.tar末端的,压缩的命令一般是以.gz末端的。
而一般情况下打包和压缩是一起进行的,打包并压缩后的文件的后缀名一般.tar.gz。
命令:tar -zcvf 打包压缩后的文件名 要打包的文件
此中:z:调用gzip压缩命令进行压缩
  c:打包文件
  v:显示运行过程
  f:指定文件名
  
示例:打包并压缩/usr/tmp 下的全部文件 压缩后的压缩包指定名称为xxx.tar
tar -zcvf ab.tar aa.txt bb.txt 
或:tar -zcvf ab.tar  *
4.2 解压

命令:tar [-zxvf] 压缩文件    
此中:x:代表解压
示例:将/usr/tmp 下的ab.tar解压到当前目录下

示例:将/usr/tmp 下的ab.tar解压到根目录/usr下
tar -xvf ab.tar -C /usr------C代表指定解压的位置

五、查找命令

5.1 grep

grep命令是一种强盛的文本搜索工具
使用实例:
  1. ps -ef | grep sshd  查找指定ssh服务进程
  2. ps -ef | grep sshd | grep -v grep 查找指定服务进程,排除gerp身
  3. ps -ef | grep sshd -c 查找指定进程个数
复制代码
5.2 find

find命令在目录结构中搜索文件,并对搜索效果实行指定的操作。 
find 默认搜索当前目录及其子目录,并且不外滤任何效果(也就是返回全部文件),将它们全都显示在屏幕上。
使用实例:
  1. find . -name "*.log" -ls  在当前目录查找以.log结尾的文件,并显示详细信息。
  2. find /root/ -perm 600   查找/root/目录下权限为600的文件
  3. find . -type f -name "*.log"  查找当目录,以.log结尾的普通文件
  4. find . -type d | sort   查找当前所有目录并排序
  5. find . -size +100M  查找当前目录大于100M的文件
复制代码
5.3 locate
locate 让使用者可以很快速的搜寻某个路径。默认每天自动更新一次,所以使用locate 命令查不到最新变动过的文件。为了制止这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库。假如数据库中没有查询的数据,则会报出locate: can not stat () `/var/lib/mlocate/mlocate.db': No such file or directory该错误!updatedb即可!
yum -y install mlocate 假如是精简版CentOS体系必要安装locate命令
使用实例:
  1. updatedb
  2. locate /etc/sh 搜索etc目录下所有以sh开头的文件
  3. locate pwd 查找和pwd相关的所有文件
复制代码
5.4 whereis

whereis命令是定位可实行文件、源代码文件、帮助文件在文件体系中的位置。这些文件的属性应属于原始代码,二进制文件,或是帮助文件。
使用实例:
  1. whereis ls    将和ls文件相关的文件都查找出来
复制代码
5.5 which

which命令的作用是在PATH变量指定的路径中,搜索某个体系命令的位置,并且返回第一个搜索效果。
使用实例:
  1. which pwd  查找pwd命令所在路径
  2. which java  查找path中java的路径
复制代码
六、su、sudo

6.1 su

su用于用户之间的切换。但是切换前的用户依然保持登录状态。假如是root 向平凡或虚拟用户切换不必要暗码,反之平凡用户切换到其它任何用户都必要暗码验证。
  1. su test:切换到test用户,但是路径还是/root目录
  2. su - test : 切换到test用户,路径变成了/home/test
  3. su : 切换到root用户,但是路径还是原来的路径
  4. su - : 切换到root用户,并且路径是/root
复制代码
su不敷:假如某个用户必要使用root权限、则必须要把root暗码告诉此用户。
退出返回之前的用户:exit
6.2 sudo
sudo是为全部想使用root权限的平凡用户设计的。可以让平凡用户具有临时使用root权限的权利。只需输入自己账户的暗码即可。
进入sudo配置文件命令:
  1. vi /etc/sudoer或者visudo
复制代码
  1. 案例:
  2. 允许hadoop用户以root身份执行各种应用命令,需要输入hadoop用户的密码。
  3. hadoop  ALL=(ALL)   ALL
  4. 案例:
  5. 只允许hadoop用户以root身份执行ls 、cat命令,并且执行时候免输入密码。
  6. 配置文件中:
  7. hadoop  ALL=NOPASSWD:  /bin/ls, /bin/cat
复制代码
七、体系服务

  1. service iptables status  --查看iptables服务的状态
  2. service iptables start  --开启iptables服务
  3. service iptables stop  --停止iptables服务
  4. service iptables restart  --重启iptables服务
  5. chkconfig iptables off  --关闭iptables服务的开机自启动
  6. chkconfig iptables on  --开启iptables服务的开机自启动
复制代码
八、网络管理

8.1 主机名配置

  1. [root@node1 ~]# vi /etc/sysconfig/network
  2. NETWORKING=yes
  3. HOSTNAME=node1
复制代码
8.2 IP 地点配置

  1. [root@node1 ~]# vi /etc/sysconfig/network-scripts/ifcfg-eth0
复制代码
8.3 域名映射

/etc/hosts文件用于在通过主机名进行访问时做ip地点分析之用。所以,你想访问一个什么样的主机名,就必要把这个主机名和它对应的ip地点。
  1. [root@node1 ~]# vi /etc/hosts
  2. #### 在最后加上
  3. 192.168.52.201  node1
  4. 192.168.52.202  node2
  5. 192.168.52.203  node3
复制代码
九、定时任务指令crontab 配置

crontab是Unix和Linux用于设置定时任务的指令。通过crontab命令,可以在固定隔断时间,实行指定的体系指令或shell脚本。时间隔断的单位可以是分钟、小时、日、月、周及以上的恣意组合。
crontab安装:
  1. yum install crontabs
复制代码
服务操作说明:
  1. service crond start   ## 启动服务
  2. service crond stop    ## 关闭服务
  3. service crond restart ## 重启服务
复制代码
9.1 命令格式
crontab [-u user] file
crontab [-u user] [ -e | -l | -r ]
参数说明:
-u user:用来设定某个用户的crontab服务  
file:file是命令文件的名字,表示将file做为crontab的任务列表文件
并载入crontab。
-e:编辑某个用户的crontab文件内容。假如不指定用户,则表示编辑当前
用户的crontab文件。
-l:显示某个用户的crontab文件内容。假如不指定用户,则表示显示当前
用户的crontab文件内容。
-r:删除定时任务配置,从/var/spool/cron目录中删除某个用户的crontab
文件,假如不指定用户,则默认删除当前用户的crontab文件。
命令示例:
  1. crontab file [-u user] ## 用指定的文件替代目前的crontab
  2. crontab -l [-u user]  ## 列出用户目前的crontab
  3. crontab -e [-u user]  ## 编辑用户目前的crontab
复制代码
9.2 配置说明、实例
命令:*   *    *   *   *   command  
表明:分  时  日  月  周  命令
第1列表示分钟1~59 每分钟用*或者 */1表示    
第2列表示小时0~23(0表示0点)
第3列表示日期1~31  
第4列表示月份1~12  
第5列标识号星期0~6(0表示星期天)  
第6列要运行的命令
配置实例:
  1. 先打开定时任务所在的文件:
  2. crontab -e
  3. 每分钟执行一次date命令
  4. */1 * * * * date >> /root/date.txt
  5. 每晚的21:30重启apache。
  6. 30 21 * * * service httpd restart
  7. 每月1、10、22日的4 : 45重启apache。  
  8. 45 4 1,10,22 * * service httpd restart
  9. 每周六、周日的1 : 10重启apache。
  10. 10 1 * * 6,0 service httpd restart
  11. 每天18 : 00至23 : 00之间每隔30分钟重启apache。
  12. 0,30   18-23    *   *   *   service httpd restart
  13. 晚上11点到早上7点之间,每隔一小时重启apache
  14. *  23-7/1    *   *   *   service httpd restart
复制代码
十、其他命令
10.1 查看当前目录:pwd
命令:pwd     查看当前目录路径
10.2 查看历程:ps -ef
命令:ps -ef    查看全部正在运行的历程
10.3 结束历程:kill
命令:kill pid 或者 kill -9 pid(逼迫杀死历程)           pid:历程号
10.4 网络通讯命令:
ifconfig:查看网卡信息
命令:ifconfig 或 ifconfig | more
ping:查看与某台机器的毗连情况
命令:ping ip
netstat -an:查看当前体系端口
命令:netstat -an
搜索指定端口
命令:netstat -an | grep 8080
10.5 配置网络
命令:setup
10.6 重启网络
命令:service network restart
10.7 切换用户
命令:su - 用户名
10.8 关闭防火墙
命令:chkconfig iptables off
或者:
  1. iptables -L;
  2. iptables -F;
  3. service iptables stop
复制代码
10.9 修改文件权限
命令:chmod 777
10.10 清屏
命令:ctrl + l
10.11 vi模式下快捷键
esc后:
生存并退出快捷键:shift+z+z
光标跳到最后一行快捷键:shift+g
删除一行:dd
复制一行内容:y+y
粘贴复制的内容:p
十一、Linux项目部署
11.1 安装jdk1.8
先卸载open-jdk
java -version
rpm -qa | grep java
rpm -e --nodeps java-1.7.0-openjdk-1.7.0.45-2.4.3.3.el6.x86_64
rpm -e --nodeps java-1.6.0-openjdk-1.6.0.0-1.66.1.13.0.el6.x86_64
开始安装:
mkdir /usr/local/src/java
rz 上传jdk tar包
tar -zxvf jdk-8u181-linux-x64.tar.gz
yum install glibc.i686
配置情况变量:
 vi /etc/profile
 在末端行添加
  #set java environment
  JAVA_HOME=/usr/local/src/jdk8/jdk1.8.0_181
  CLASSPATH=.JAVA_HOME/lib.tools.jar
  PATH=$JAVA_HOME/binPATH
  export JAVA_HOME CLASSPATH PATH
  
生存退出
source /etc/profile  使更改的配置立即见效
java -version  查看JDK版本信息,假如显示出1.8证明乐成
11.2 安装MySQL5.6
11.2.1 上传MySQL5.6的tar包
创建目录:mkdir /usr/local/src/mysql5.6
上传:MySQL-5.6.34-1.rhel5.x86_64.rpm-bundle.tar 到上面的目录中
11.2.2 安装
第一步:解压
     命令:tar -xvf MySQL-5.6.34-1.rhel5.x86_64.rpm-bundle.tar
第二步:检测是否已经安装了mysql
     命令:rpm -qa | grep mysql   
     假如已经安装了,将其卸载,如:
     rpm -e --nodeps  mysql-libs-5.1.71-1.el6.x86_64
第三步:安装MySQL的服务端
     命令:rpm -ivh MySQL-server-5.6.34-1.rhel5.x86_64.rpm
第四步:安装MySQL的客户端
     命令:rpm -ivh MySQL-client-5.6.34-1.rhel5.x86_64.rpm
第五步:查看MySQL服务运行状态
     命令:service mysql status
第六步:启动MySQL服务
     命令:service mysql start
第七步:使用root账号登录mysql
在安装mysql server时有句提示:

注意:这个暗码是不安全的,全部必要修改初始暗码。

  • 使用暗码登录mysql账号:mysql -uroot -p
  • 修改root暗码:SET PASSWORD = PASSWORD('root');
11.2.3 开机自动启动设置
加入到体系服务:
chkconfig --add mysql
自动启动:
chkconfig mysql on
查询列表:
chkconfig
说明:都没关闭(off)时是没有自动启动。
11.2.4 开启远程访问
登录:
mysql -uroot –proot
设置远程访问(使用root暗码):
grant all privileges on *.* to 'root' @'%' identified by 'root';
flush privileges;
退出mysql,在centos情况下打开3306防火墙
/sbin/iptables -I INPUT -p tcp --dport 3306 -j ACCEPT
/etc/rc.d/init.d/iptables save
/etc/init.d/iptables status
11.3 安装tomcat部署项目
预备工作:将web项目打成war包,改名为ROOT.war
11.3.1 创建ucenter用户
一般情况下,发布应用步调都不是使用root用户的,必要创建一个平凡用户来发布步调;
创建ucenter用户:
useradd -d /ucenter ucenter
设置暗码:
passwd ucenter (暗码 ucenter)
切换用户:
su - ucenter
11.3.2 安装Tomcat
tomcat只要解压就可以使用。
1、创建web目录
mkdir /ucenter/web
2、上传apache-tomcat-7.0.57.tar.gz
3、解压:tar -xvf apache-tomcat-7.0.57.tar.gz
4、重定名:mv apache-tomcat-7.0.57 itcast-usermanage
5、启动tomcat:
     cd itcast-usermanage/bin/
     ./startup.sh 或者 sh startup.sh
6、查看日记:
     tail -f ../logs/catalina.out
7、查看效果 http://192.168.0.160:8080/
发现无法访问:

 
8、防火墙打开 8080 端口
     /sbin/iptables -I INPUT -p tcp --dport 8080 -j ACCEPT
     /etc/rc.d/init.d/iptables save
9、安装乐成

11.3.3 部署用户管理项目
1、上传usermanage.sql和ROOT.war到/ucenter/web
2、实行数据库脚本
     cat user_manager.sql | mysql -uroot -p123456
3、部署web步调
3.1 删除webapps下的全部文件
     cd /ucenter/web/usermanage/webapps
     rm -rf *
3.2 拷贝ROOT.war到webapps
     cp /ucenter/web/ROOT.war .
3.3 重新启动tomcat
     cd ../bin/
     sh startup.sh && tail -f ../logs/catalina.out
3.4 启动浏览器测试
注意事项:Centos情况下部署项目中文乱码问题解决方案
    今天在一台新的CentOS机器上使用c3p0毗连池操作mysql数据库出现中文乱码问题,详细体现为:查询时无中文乱码问题,写数据时中文乱码,查看了机器上数据库字符集也是UTF8,应该不会出现中文乱码才对,最后在c3p0配置文件中 jdbcUrl后加上:?useUnicode=true&characterEncoding=UTF8 中文就不会乱码了。
【C3P0配置文件】
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <c3p0-config>
  3.   <default-config>
  4.     <property name="driverClass">com.mysql.jdbc.Driver</property>
  5.         <property name="jdbcUrl">jdbc:mysql://localhost:3306/user_manager_yun6?useUnicode=true&amp;characterEncoding=UTF8 </property>
  6.         <property name="user">root</property>
  7.         <property name="password">root</property>
  8.         <property name="acquireIncrement">2</property>
  9.         <property name="initialPoolSize">5</property>
  10.         <property name="minPoolSize">1</property>
  11.         <property name="maxPoolSize">5</property>
  12.   </default-config>
  13. </c3p0-config>
复制代码
 
11.4 Linux下使用FastDFS
相干的安装包我打包到云盘上了,链接:https://pan.baidu.com/s/13NDYYil4mgLhkb5CYsc2Ww  提取码:66tn
单节点FastDFS
整个安装过程非常复杂,很容易出错,建议进行多次备份。
我们这里不打算安装多台虚拟机,因此会把tracker和storage都安装在一起。
11.4.1 安装gcc
GCC用来对C语言代码进行编译运行,使用yum命令安装:
  1. yum -y install gcc
复制代码
 后面会用到解压命令(unzip),所以这里可以用yum把unzip 也装一下
  1. yum install -y unzip zip
复制代码
11.4.2 安装libevent

  1. yum -y install libevent
复制代码
11.4.3 安装libfastcommon-master
解压刚刚上传的libfastcommon-master.zip
unzip libfastcommon-master.zip
进入解压完成的目录
cd libfastcommon-master
编译并且安装:
./make.sh 
./make.sh install
11.4.4 安装fastdfs
  1. tar -zxvf FastDFS_v5.08.tar.gz
  2. cd FastDFS
  3. ./make.sh
  4. ./make.sh install
复制代码
假如安装乐成,会看到/etc/init.d/下看到提供的脚本文件:
  1. ll /etc/init.d/ | grep fdfs
复制代码



  • fdfs_trackerd 是tracker启动脚本
  • fdfs_storaged 是storage启动脚本
能够在 /etc/fdfs/ 目录下看到默认的配置文件模板:
 
  1. ll /etc/fdfs/
复制代码



  • tarcker.conf.sample 是tracker的配置文件模板
  • storage.conf.sample 是storage的配置文件模板
  • client.conf.sample 是客户端的配置文件模板
 
11.4.5 配置并启动tracker服务

1)起首将模板文件复制
  1. cp /etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf
复制代码
2)修改复制后的配置文件:
  1. vim /etc/fdfs/tracker.conf
复制代码
# 修改的内容如下:
  1. base_path=/项目名/tracker                 # 存储日志和数据的根目录
复制代码
3)新建目录:
  1. mkdir -p /项目名/tracker
复制代码
注意:关闭防火墙:
  1. chkconfig iptables off
复制代码
 4)启动和制止
  1. service fdfs_trackerd start # 启动fdfs_trackerd服务,停止用stop
复制代码
 检查FastDFS Tracker Server是否启动乐成:
  1. ps -ef | grep fdfs_trackerd
复制代码
 设置tracker服务开机启动:
  1. chkconfig fdfs_trackerd on
复制代码
 
11.4.6 配置并启动storage服务

1)起首将模板文件复制
  1. cp /etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf
复制代码
2)修改复制后的配置文件:
  1. vim /etc/fdfs/storage.conf
复制代码
# 修改的内容如下
  1. base_path=/项目名/storage                 # 数据和日志文件存储根目录
  2. store_path0=/项目名/storage               # 第一个存储目录
  3. tracker_server=192.168.56.101:22122       #  tracker服务器IP和端口
复制代码
3)新建目录:
  1. mkdir -p /项目名/storage
复制代码
注意关闭防火墙: chkconfig iptables off
4)启动和制止
  1. service fdfs_storaged start  # 启动fdfs_storaged服务,停止用stop
复制代码
设置storage服务开机启动:
  1. chkconfig fdfs_storaged on
复制代码
ps -ef | grep fdfs

11.5 安装fastdfs-nginx-module

11.5.1 解压

  1. tar -zxvf fastdfs-nginx-module_v1.16.tar.gz
复制代码
11.5.2 修改config

1)进入src目录
  1. cd fastdfs-nginx-module/src/
复制代码
2)编辑config
  1. vim config
复制代码
使用以下底行命令:
  1. :%s+/usr/local/+/usr/+g
复制代码
将全部的/usr/local替换为 /usr,这个才是正确的目录:

11.5.3 配置nginx与FastDFS关联配置文件

复制 fastdfs-nginx-module 源码中的配置文件到/etc/fdfs 目录, 并修改
  1. cp /usr/local/项目名/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/
  2. vi /etc/fdfs/mod_fastdfs.conf
复制代码
修改以下配置:
  1. connect_timeout=10                        # 客户端访问文件连接超时时长(单位:秒)
  2. tracker_server=192.168.56.101:22122       # tracker服务IP和端口
  3. url_have_group_name=true                  # 访问链接前缀加上组名
  4. store_path0=/leyou/storage                # 文件存储路径
复制代码
复制 FastDFS 的部分配置文件到/etc/fdfs 目录
  1. cd /usr/local/项目名/FastDFS/conf/
  2. cp http.conf mime.types /etc/fdfs/
复制代码
11.6 安装Nginx的插件

11.6.1 假如没有安装过nginx

1、安装nginx的依赖库
  1. yum -y install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel
复制代码
2、解压安装包
tar -zxvf nginx-1.10.0.tar.gz
3、配置nginx安装包,并指定fastdfs-nginx-model
  1. cd nginx-1.10.0
  2. ./configure --prefix=/opt/nginx --sbin-path=/usr/bin/nginx --add-module=/usr/local/leyou/fastdfs-nginx-module/src
复制代码
注意:在实行./configure配置nginx参数的时间,必要将fastdfs-nginx-moudle源码作为模块编译进去。
4、编译并安装
  1. make && make install
复制代码
11.6.2 假如已经安装过nginx

1、 进入nginx目录:
  1. cd /usr/local/项目名/nginx-1.10.0/
复制代码
2、 配置FastDFS 模块
  1. ./configure --prefix=/opt/nginx --sbin-path=/usr/bin/nginx --add-module=/usr/local/项目名/fastdfs-nginx-module/src
复制代码
注意:这次配置时,要添加fastdfs-nginx-moudle模块
3、编译,注意,这次不要安装(install)
  1. make
复制代码
4、替换nginx二进制文件:
备份:
  1. mv /usr/bin/nginx /usr/bin/nginx-bak
复制代码
用新编译的nginx启动文件替换原来的:
  1. cp objs/nginx /usr/bin/
复制代码
11.6.3 启动nginx

配置nginx整合fastdfs-module模块
我们必要修改nginx配置文件,在/opt/nginx/config/nginx.conf文件中:
  1. vim  /opt/nginx/conf/nginx.conf
复制代码
将文件中,原来的server 80{ ...} 部分代码替换为如下代码:
  1. server {
  2.     listen       80;
  3.     server_name  image.项目名.com;
  4.         # 监听域名中带有group的,交给FastDFS模块处理
  5.     location ~/group([0-9])/ {
  6.         ngx_fastdfs_module;
  7.     }
  8.     location / {
  9.         root   html;
  10.         index  index.html index.htm;
  11.     }
  12.     error_page   500 502 503 504  /50x.html;
  13.     location = /50x.html {
  14.         root   html;
  15.     }
  16. }
复制代码
启动nginx:
  1. nginx                    # 启动nginx
  2. nginx -s stop            # 停止nginx
  3. nginx -s reload            # 重新载入配置文件
复制代码
# 可通过ps -ef | grep nginx查看nginx是否已启动乐成

11.6.4 设置nginx开机启动

创建一个开机启动的脚本:
  1. vim /etc/init.d/nginx
复制代码
添加以下内容:
  1. #!/bin/sh
  2. #
  3. # nginx - this script starts and stops the nginx daemon
  4. #
  5. # chkconfig:   - 85 15
  6. # description:  NGINX is an HTTP(S) server, HTTP(S) reverse \
  7. #               proxy and IMAP/POP3 proxy server
  8. # processname: nginx
  9. # config:      /etc/nginx/nginx.conf
  10. # config:      /etc/sysconfig/nginx
  11. # pidfile:     /var/run/nginx.pid
  12. # Source function library.
  13. . /etc/rc.d/init.d/functions
  14. # Source networking configuration.
  15. . /etc/sysconfig/network
  16. # Check that networking is up.
  17. [ "$NETWORKING" = "no" ] && exit 0
  18. nginx="/usr/bin/nginx"
  19. prog=$(basename $nginx)
  20. NGINX_CONF_FILE="/opt/nginx/conf/nginx.conf"
  21. [ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx
  22. lockfile=/var/lock/subsys/nginx
  23. make_dirs() {
  24.    # make required directories
  25.    user=`$nginx -V 2>&1 | grep "configure arguments:.*--user=" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`
  26.    if [ -n "$user" ]; then
  27.       if [ -z "`grep $user /etc/passwd`" ]; then
  28.          useradd -M -s /bin/nologin $user
  29.       fi
  30.       options=`$nginx -V 2>&1 | grep 'configure arguments:'`
  31.       for opt in $options; do
  32.           if [ `echo $opt | grep '.*-temp-path'` ]; then
  33.               value=`echo $opt | cut -d "=" -f 2`
  34.               if [ ! -d "$value" ]; then
  35.                   # echo "creating" $value
  36.                   mkdir -p $value && chown -R $user $value
  37.               fi
  38.           fi
  39.        done
  40.     fi
  41. }
  42. start() {
  43.     [ -x $nginx ] || exit 5
  44.     [ -f $NGINX_CONF_FILE ] || exit 6
  45.     make_dirs
  46.     echo -n $"Starting $prog: "
  47.     daemon $nginx -c $NGINX_CONF_FILE
  48.     retval=$?
  49.     echo
  50.     [ $retval -eq 0 ] && touch $lockfile
  51.     return $retval
  52. }
  53. stop() {
  54.     echo -n $"Stopping $prog: "
  55.     killproc $prog -QUIT
  56.     retval=$?
  57.     echo
  58.     [ $retval -eq 0 ] && rm -f $lockfile
  59.     return $retval
  60. }
  61. restart() {
  62.     configtest || return $?
  63.     stop
  64.     sleep 1
  65.     start
  66. }
  67. reload() {
  68.     configtest || return $?
  69.     echo -n $"Reloading $prog: "
  70.     killproc $nginx -HUP
  71.     RETVAL=$?
  72.     echo
  73. }
  74. force_reload() {
  75.     restart
  76. }
  77. configtest() {
  78.   $nginx -t -c $NGINX_CONF_FILE
  79. }
  80. rh_status() {
  81.     status $prog
  82. }
  83. rh_status_q() {
  84.     rh_status >/dev/null 2>&1
  85. }
  86. case "$1" in
  87.     start)
  88.         rh_status_q && exit 0
  89.         $1
  90.         ;;
  91.     stop)
  92.         rh_status_q || exit 0
  93.         $1
  94.         ;;
  95.     restart|configtest)
  96.         $1
  97.         ;;
  98.     reload)
  99.         rh_status_q || exit 7
  100.         $1
  101.         ;;
  102.     force-reload)
  103.         force_reload
  104.         ;;
  105.     status)
  106.         rh_status
  107.         ;;
  108.     condrestart|try-restart)
  109.         rh_status_q || exit 0
  110.             ;;
  111.     *)
  112.         echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"
  113.         exit 2
  114. esac
复制代码
修改文件权限,并加入服务列表
  1. # 修改权限
  2. chmod 777 /etc/init.d/nginx
  3. # 添加到服务列表
  4. chkconfig --add /etc/init.d/nginx
复制代码
设置开机启动
  1. chkconfig nginx on
复制代码
11.7 安装Elasticsearch

必要虚拟机JDK1.8及以上
11.7.1 新建一个用户leyou

出于安全考虑,elasticsearch默认不允许以root账号运行。
创建用户:
  1. useradd leyou
复制代码
设置暗码:
  1. passwd leyou
复制代码
切换用户:
  1. su - leyou
复制代码
11.7.2 上传安装包,并解压

我们将安装包上传到:/home/leyou目录
解压缩:
  1. tar -zxvf elasticsearch-6.2.4.tar.gz
复制代码
我们把目录重定名:
  1. mv elasticsearch-6.3.0/ elasticsearch
复制代码

进入,查看目录结构:

11.7.3 修改配置

我们进入config目录:cd config
必要修改的配置文件有两个:

 
1、jvm.options
Elasticsearch基于Lucene的,而Lucene底层是java实现,因此我们必要配置jvm参数。
编辑jvm.options:
  1. vim jvm.options
复制代码
默认配置如下:
-Xms1g
-Xmx1g
内存占用太多了,我们调小一些:
-Xms512m
-Xmx512m
2、elasticsearch.yml
  1. vim elasticsearch.yml
复制代码
修改数据和日记目录:
  1. path.data: /home/leyou/elasticsearch/data # 数据目录位置
  2. path.logs: /home/leyou/elasticsearch/logs # 日志目录位置
复制代码
我们把data和logs目录修改指向了elasticsearch的安装目录。但是这两个目录并不存在,因此我们必要创建出来。
进入elasticsearch的根目录,然后创建:
  1. mkdir data
  2. mkdir logs
复制代码

修改绑定的ip:
  1. network.host: 0.0.0.0 # 绑定到0.0.0.0,允许任何ip来访问
复制代码
默认只允许本机访问,修改为0.0.0.0后则可以远程访问
11.7.4 运行

进入elasticsearch/bin目录,可以看到下面的实行文件:

然后输入命令:
  1. ./elasticsearch
复制代码
或者后台运行:
  1. ./elasticsearch -d
复制代码
11.7.5 错误1:内核过低


修改elasticsearch.yml文件,在最下面添加如下配置: 然后重启
  1. bootstrap.system_call_filter: false
复制代码
11.7.6 错误2:文件权限不敷


我们用的是leyou用户,而不是root,所以文件权限不敷。
起首用root用户登录。直接输入exit命令
然后修改配置文件:
  1. vim /etc/security/limits.conf
复制代码
添加下面的内容:
  1. * soft nofile 65536
  2. * hard nofile 131072
  3. * soft nproc 4096
  4. * hard nproc 4096
复制代码
11.7.7 错误3:线程数不够

[1]: max number of threads [1024] for user [leyou] is too low, increase to at least [4096]
继承修改配置:
  1. vim /etc/security/limits.d/90-nproc.conf
复制代码
修改下面的内容:
  1. * soft nproc 1024
复制代码
改为
  1. * soft nproc 4096
复制代码
11.7.8 错误4:历程虚拟内存
[3]: max virtual memory areas vm.max_map_count [65530] likely too low, increase to at least [262144]
vm.max_map_count:限制一个历程可以拥有的VMA(虚拟内存区域)的数目,继承修改配置文件 :
  1. vim /etc/sysctl.conf
复制代码
添加下面内容:
  1. vm.max_map_count=655360
复制代码
然后实行命令:
  1. sysctl -p
复制代码
 
11.7.9 重启终端窗口

全部错误修改完毕,肯定要重启你的 Xshell终端,否则配置无效。
11.8 安装RabbitMQ

  1. cd /usr/local/myapp
  2. mkdir rabbitmq
  3. cd rabbitmq
复制代码
11.8.1 安装Erlang

1、在线安装
  1. yum install esl-erlang_17.3-1~centos~6_amd64.rpm
  2. yum install esl-erlang-compat-R14B-1.el6.noarch.rpm
复制代码
2、离线安装

依次实行命令:
1)rpm -ivh esl-erlang-17.3-1.x86_64.rpm --force --nodeps

2)rpm -ivh esl-erlang_17.3-1~centos~6_amd64.rpm --force --nodeps

3)rpm -ivh esl-erlang-compat-R14B-1.el6.noarch.rpm --force --nodeps

11.8.2 安装RabbitMQ


安装
  1. rpm -ivh rabbitmq-server-3.4.1-1.noarch.rpm
复制代码

11.8.3 设置配置文件

  1. cp /usr/share/doc/rabbitmq-server-3.4.1/rabbitmq.config.example
  2. /etc/rabbitmq/rabbitmq.config
复制代码
开启用户远程访问
  1. vi /etc/rabbitmq/rabbitmq.config
复制代码

注意要去掉后面的逗号。
11.8.4 启动、制止

  1. service rabbitmq-server start
  2. service rabbitmq-server stop
  3. service rabbitmq-server restart
复制代码
11.8.5 开启web界面管理工具

  1. rabbitmq-plugins enable rabbitmq_management
  2. service rabbitmq-server restart
复制代码
11.8.6 设置开机启动

  1. chkconfig rabbitmq-server on
复制代码
11.8.7 防火墙开放15672端口

  1. /sbin/iptables -I INPUT -p tcp --dport 15672 -j ACCEPT
  2. /etc/rc.d/init.d/iptables save
复制代码
11.9 redis安装和配置

11.9.1 安装

解压
  1. tar -xvf redis-4.0.9.tar.gz
复制代码
编译安装
  1. mv redis-4.0.9 redis cd redis make && make install
复制代码
11.9.2 配置

修改安装目录下的redis.conf文件
  1. vim redis.conf
复制代码
修改以下配置:
  1. #bind 127.0.0.1 # 将这行代码注释,监听所有的ip地址,外网可以访问
  2. protected-mode no # 把yes改成no,允许外网访问
  3. daemonize yes # 把no改成yes,后台运行
复制代码
11.9.3 启动或制止
redis提供了服务端命令和客户端命令:
redis-server 服务端命令,可以包含以下参数: start 启动 stop 制止
redis-cli 客户端控制台,包含参数: -h xxx 指定服务端地点,缺省值是127.0.0.1 -p xxx 指定服务端端口,缺省值是6379
11.9.4 设置开机启动
1) 输入命令,新建文件
  1. vim /etc/init.d/redis
复制代码
输入下面内容:
  1. #!/bin/sh
  2. # chkconfig:   2345 90 10
  3. # description:  Redis is a persistent key-value database
  4. PATH=/usr/local/bin:/sbin:/usr/bin:/bin
  5. REDISPORT=6379
  6. EXEC=/usr/local/bin/redis-server
  7. REDIS_CLI=/usr/local/bin/redis-cli
  8. PIDFILE=/var/run/redis.pid
  9. CONF="/usr/local/leyou/redis/redis.conf"
  10. case "$1" in  
  11.     start)  
  12.         if [ -f $PIDFILE ]  
  13.         then  
  14.                 echo "$PIDFILE exists, process is already running or crashed"  
  15.         else  
  16.                 echo "Starting Redis server..."  
  17.                 $EXEC $CONF  
  18.         fi  
  19.         if [ "$?"="0" ]   
  20.         then  
  21.               echo "Redis is running..."  
  22.         fi  
  23.         ;;  
  24.     stop)  
  25.         if [ ! -f $PIDFILE ]  
  26.         then  
  27.                 echo "$PIDFILE does not exist, process is not running"  
  28.         else  
  29.                 PID=$(cat $PIDFILE)  
  30.                 echo "Stopping ..."  
  31.                 $REDIS_CLI -p $REDISPORT SHUTDOWN  
  32.                 while [ -x ${PIDFILE} ]  
  33.                do  
  34.                     echo "Waiting for Redis to shutdown ..."  
  35.                     sleep 1  
  36.                 done  
  37.                 echo "Redis stopped"  
  38.         fi  
  39.         ;;  
  40.    restart|force-reload)  
  41.         ${0} stop  
  42.         ${0} start  
  43.         ;;  
  44.   *)  
  45.     echo "Usage: /etc/init.d/redis {start|stop|restart|force-reload}" >&2  
  46.         exit 1  
  47. esac
复制代码
然后生存退出
注意:以下信息必要根据安装目录进行调解:
  1. EXEC=/usr/local/bin/redis-server                 # 执行脚本的地址
  2. REDIS_CLI=/usr/local/bin/redis-cli               # 客户端执行脚本的地址
  3. PIDFILE=/var/run/redis.pid                       # 进程id文件地址
  4. CONF="/usr/local/src/redis-3.0.2/redis.conf"     #配置文件地址
复制代码
2)设置权限
  1. chmod 755 /etc/init.d/redis
复制代码
3)启动测试
  1. /etc/init.d/redis start
复制代码
启动乐成会提示如下信息:
Starting Redis server...
Redis is running...
4)设置开机自启动
  1. chkconfig --add /etc/init.d/redis
  2. chkconfig redis on
复制代码
 

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

拉不拉稀肚拉稀

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表