本文总结了很多CentOS上常见开发工具的安装和简单使用说明。

服务器环境准备集合

PS.该教程所有步骤都需在root用户权限下操作

安装前准备:

yum -y groupinstall 'Development Tools'
yum -y install yum-fastestmirror
yum -y install glibc-static libstdc++-static glibc-devel GeoIP GeoIP-devel sqlite-devel
yum -y install patch make flex bison tar pcre pcre-devel screen vsftpd ftp
yum -y install libtool libtool-libs kernel-devel autoconf
yum -y install libjpeg libjpeg-devel libpng libpng-devel
yum -y install libtiff libtiff-devel gettext gettext-devel
yum -y install freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel
yum -y install file glib2 glib2-devel bzip2 openldap-devel
yum -y install bzip2-devel ncurses ncurses-devel curl curl-devel e2fsprogs
yum -y install e2fsprogs-devel krb5-devel libidn libidn-devel
yum -y install openssl openssl-devel vim-minimal unzip
yum -y install libevent mcrypt mash libssh2 libssh2-devel libmetalink libmetalink-devel nghttp2
yum -y install gd recode recode-devel libatomic_ops-devel
yum -y install libXpm libXpm-devel gmp gmp-devel gd-devel
export PHP_AUTOCONF=/usr/bin/autoconf
export PHP_AUTOHEADER=/usr/bin/autoheader
yum -y update

I、为GCP开启远程SSH权限

①、使用Web SSH登录,将用户切换为root
sudo -i
②、 修改ssh配置
vi /etc/ssh/sshd_config

修改以下内容:

PermitRootLogin yes
PasswordAuthentication yes
③、重启sshd
service sshd restart
④、重置root密码
passwd root

II、安装ZSHZSH插件

Zsh同Bash一样,是一款功能强大的终端(shell)软件,只不过bash是大部分Linux发行版默认的shell,而Zsh需要手动安装(mac默认已安装),本文主要讲述在CentOS上安装并使用Zsh作为默认的Shell

①、安装curlwgetgitzsh
yum -y groupinstall 'Development Tools'
yum -y install curl wget git zsh lsof
②、查看当前所有已安装的Shell
cat /etc/shells

得到结果如下:

/bin/sh
/bin/bash
/usr/bin/sh
/usr/bin/bash
/bin/zsh

如上所示,目前已经支持Zsh,需要把系统默认的Shell由Bash切换为Zsh

③、切换SHELL至Zsh
chsh -s /bin/zsh

chsh用法请自行查找,返回结果如下:

Changing shell for root.
Shell changed.

按提示所述,Shell已经更改为Zsh了,需要退出SSH并重新连接,再次连接后输出当前SHELL:

echo $SHELL

返回结果如下:

/bin/zsh

如果上面结果不是/bin/zsh则表明SHELL还没有切换成功,则需要重启服务器,重启后再次尝试输出当前SHELL,一般只要重连SSH就会切换成功,切换成功后就可以安装oh-my-zsh

④、安装Oh-My-Zsh

想看官网安装教程的请移步:Oh-My-Zsh

1、通过curl方式安装
sh -c "$(curl -fsSL https://raw.github.com/robbyrussell/oh-my-zsh/master/tools/install.sh)"
2、通过wget方式安装
sh -c "$(wget https://raw.github.com/robbyrussell/oh-my-zsh/master/tools/install.sh -O -)"

如果显示如下界面表示成功:

         __                                     __
  ____  / /_     ____ ___  __  __   ____  _____/ /_
 / __ \/ __ \   / __ `__ \/ / / /  /_  / / ___/ __ \
/ /_/ / / / /  / / / / / / /_/ /    / /_(__  ) / / /
\____/_/ /_/  /_/ /_/ /_/\__, /    /___/____/_/ /_/
                        /____/                       ....is now installed!

Please look over the ~/.zshrc file to select plugins, themes, and options.

p.s. Follow us at https://twitter.com/ohmyzsh.

p.p.s. Get stickers, shirts, and coffee mugs at https://shop.planetargon.com/collections/oh-my-zsh.

这时,Oh-My-Zsh就安装完成了,接下来介绍Oh-My-Zsh的使用

3、安装ZSH插件

Zsh的默认配置文件为~/.zshrc

①、插件配置

插件配置选项为:plugins=(git bundler osx rake ruby),可供选择的插件列表为:Zsh插件列表

  • 安装高亮插件 zsh-syntax-highlighting

    # git地址:https://github.com/zsh-users/zsh-syntax-highlighting
    
    # 安装教程:
    git clone https://github.com/zsh-users/zsh-syntax-highlighting.git ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-syntax-highlighting
    # 添加plugins:zsh-syntax-highlighting
    plugins=( [plugins...] zsh-syntax-highlighting)
    

②、主题配置

主题配置选项为:ZSH_THEME=”robbyrussell”,可供选择的主题列表为:Zsh主题列表

  • 推荐主题配色,修改~/.zshrc

    export CLICOLOR=1
    export LSCOLORS=Gxfxcxdxbxegedabagacad
    export GREP_OPTIONS="--color=auto"
    
  • 推荐主题agnoster

接下来就尽情享用Oh-My-Zsh吧。

III、升级系统自带Python2版本

①、安装基础组件
yum -y install yum-utils
yum-builddep -y python
yum -y install bzip2-devel
yum -y install ncurses-devel
yum -y install sqlite-devel
yum -y install gdbm-devel
yum -y install xz-devel
yum -y install tk-devel
yum -y install readline-devel
②、下载并解压源码

通过Python官网下载Python2.7源码:

cd ~ && wget https://www.python.org/ftp/python/2.7.16/Python-2.7.16.tgz
tar -zxvf Python-2.7.16.tgz
cd Python-2.7.16
③、修改对SSL的支持

修改文件Modules/Setup.dist,内容如下:

# Socket module helper for socket(2)
_socket socketmodule.c timemodule.c

# Socket module helper for SSL support; you must comment out the other
# socket line above, and possibly edit the SSL variable:
SSL=/usr/local/ssl
_ssl _ssl.c \
       -DUSE_SSL -I$(SSL)/include -I$(SSL)/include/openssl \
       -L$(SSL)/lib -lssl -lcrypto
# Andrew Kuchling's zlib module.
# This require zlib 1.1.3 (or later).
# See http://www.gzip.org/zlib/
zlib zlibmodule.c -I$(prefix)/include -L$(exec_prefix)/lib -lz
④、编译安装
# ./configure --enable-optimizations --prefix=/usr/local/python2 --enable-unicode=ucs4
./configure --enable-optimizations
make && make install
make clean
⑤、备份老版本,创建新版本软链

旧版本目录:ll -tr /usr/bin/python* 新版本目录:ll -tr /usr/local/bin/python*

rm -f /usr/bin/python
rm -f /usr/bin/python-config
ln -s /usr/local/bin/python /usr/bin/python
ln -s /usr/local/bin/python-config /usr/bin/python-config
# ln -s /usr/local/include/python2.7/ /usr/include/python2.7
⑥、安装pip
cd ~ && wget https://bootstrap.pypa.io/get-pip.py -O - | python

安装完成后,查看当前Python版本:

python --version

显示结果如下:

Python 2.7.16

如果上述命令出错,修改配置文件/etc/ld.so.conf,添加新的一行:/usr/local/lib*,然后执行命令sudo /sbin/ldconfig -v,然后重新输入命令python -V

⑦、修改yum相关的命令

修改以下文件首行内容:

/bin/yum
/bin/yum-config-manager
/usr/libexec/urlgrabber-ext-down
/bin/firewall-cmd
/usr/sbin/yum-cron

修改内容如下:

#!/usr/bin/python2.7

PS.修改yum的内容是避免在使用yum命令时报错,所以将yum中使用的python版本改为系统自带匹配版本

IV、安装Go

①、下载并解压安装包
cd ~ && wget https://dl.google.com/go/go1.12.1.linux-amd64.tar.gz
tar -zxvf go1.12.1.linux-amd64.tar.gz -C /opt/
mkdir -p /opt/gopath

安装完成后GOROOT/opt/goGOPATH/opt/gopath

②、修改profile设置

修改/etc/profile~/.zshrc

export GOROOT=/opt/go
export GOBIN=$GOROOT/bin
export GOPKG=$GOROOT/pkg/tool/linux_amd64
export GOARCH=amd64
export GOOS=linux
export GOPATH=/opt/gopath
export PATH=$PATH:$GOBIN:$GOPKG:$GOPATH/bin

使修改生效source /etc/profilesource ~/.zshrc

安装成功查看Go Version

go version结果go version go1.12.1 linux/amd64

V、安装ShadowSocks-Go

①、安装bbr
wget --no-check-certificate https://github.com/teddysun/across/raw/master/bbr.sh
chmod +x bbr.sh
./bbr.sh
②、安装ShadowSocks-Go,详见 教程
wget --no-check-certificate https://raw.githubusercontent.com/teddysun/shadowsocks_install/master/shadowsocks-all.sh
chmod +x shadowsocks-all.sh
./shadowsocks-all.sh 2>&1 | tee shadowsocks-all.log

./shadowsocks-all.sh uninstall

/etc/init.d/shadowsocks-go start | stop | restart | status

VI、安装Python3

curl -O https://www.python.org/ftp/python/3.7.3/Python-3.7.3.tgz
tar -zxvf Python-3.7.3.tgz
cd Python-3.7.3
./configure --enable-optimizations
make && make install
make clean

过程中修改Modules/Setup.dist的步骤参考Python2的升级方法。

升级Pip3

pip3 install --upgrade pip

使用Python3遇到的错误及解决办法

# 错误:No module named 'ConfigParser'
# 解决方案:
cp /usr/local/lib/python3.7/configparser.py /usr/local/lib/python3.7/ConfigParser.py
# 错误:OSError: mysql_config not found
# 解决方案:在~/.zshrc中加入MySQL的PATH
export PATH=$PATH:/usr/local/mysql/bin/
# pip3 会覆盖python2.7.16升级的pip
rm -f /usr/local/bin/pip
ln -s /usr/local/bin/pip2 /usr/local/bin/pip

VII、安装SSDB

cd ~ && wget --no-check-certificate https://github.com/ideawu/ssdb/archive/master.zip -O SSDB-Master.zip
unzip SSDB-Master.zip
cd ssdb-master
# 默认安装在 /usr/local/ssdb 目录下,可通过make install PREFIX=/your/direcotry修改安装目录
make && make install
mkdir -p /opt/ssdb_data/var
cp ~/ssdb-master/ssdb.conf /opt/ssdb_data/
cp ~/ssdb-master/tools/ssdb.sh /etc/init.d/ssdb
# 修改configs地址
sudo chkconfig --add ssdb
sudo chkconfig ssdb on
systemctl start ssdb
# 自启动脚本教程
http://ssdb.io/docs/zh_cn/install.html
# 使用命令操作SSDB
systemctl start/stop/restart ssdb.service

# 在修改了/etc/init.d/ssdb配置文件后,需要使用如下命令使配置生效:
systemctl daemon-reload

VIII、安装Redis

①、下载安装包:
cd ~ && wget http://download.redis.io/releases/redis-5.0.4.tar.gz
tar -zxvf redis-5.0.4.tar.gz
cd redis-5.0.4
make && make install
make test
mkdir -p /etc/redis
# 复制配置文件
cp redis.conf /etc/redis/6379.conf
# 复制开机启动脚本
cp utils/redis_init_script /etc/init.d/redisd
# 添加服务并设置开机启动
sudo chkconfig --add redisd
sudo chkconfig redisd on
# 启动redis
systemctl start redisd
# 修改配置文件
daemonize yes
requirepass foobared
bind 127.0.0.1

IX、安装LNMP

使用LNMP一键安装包搭建服务器

①、下载LNMP一键安装包并安装
wget http://soft.vpser.net/lnmp/lnmp1.6.tar.gz -cO lnmp1.6.tar.gz && tar zxf lnmp1.6.tar.gz && cd lnmp1.6 && ./install.sh lnmp
②、 LNMP安装目录及配置文件地址:
# 说明:https://lnmp.org/faq/lnmp-software-list.html
# Nginx 目录: 
/usr/local/nginx/
# MySQL 目录 : 
/usr/local/mysql/
# MySQL数据库所在目录:
/usr/local/mysql/var/
# PHP目录 : 
/usr/local/php/
# PHPMyAdmin目录 : 
/home/wwwroot/default/phpmyadmin/ 
# 默认网站目录 :
/home/wwwroot/default/
# Nginx日志目录:
/home/wwwlogs/
# 添加的虚拟主机配置文件所在目录:
/usr/local/nginx/conf/vhost/
# PureFtpd 目录:
/usr/local/pureftpd/
# PureFtpd web管理目录:
/home/wwwroot/default/ftp/
# Proftpd 目录:
/usr/local/proftpd/

# LNMP相关配置文件位置
# Nginx主配置(默认虚拟主机)文件:
/usr/local/nginx/conf/nginx.conf
#添加的虚拟主机配置文件:
/usr/local/nginx/conf/vhost/域名.conf
# MySQL配置文件:
/etc/my.cnf
# PHP配置文件:
/usr/local/php/etc/php.ini
# php-fpm配置文件:
/usr/local/php/etc/php-fpm.conf
# PureFtpd配置文件:
/usr/local/pureftpd/etc/pure-ftpd.conf
# PureFtpd MySQL配置文件:/usr/local/pureftpd/pureftpd-mysql.conf
# Proftpd配置文件:
/usr/local/proftpd/etc/proftpd.conf
# Proftpd 用户配置文件:
/usr/local/proftpd/etc/vhost/用户名.conf
③、LNMP常用操作命令
# LNMP状态管理:
lnmp {start|stop|reload|restart|kill|status}
# LNMP各个程序的状态管理:
lnmp {nginx|mysql|mariadb|php-fpm|pureftpd} {start|stop|reload|restart|kill|status}
# 虚拟主机管理:
lnmp vhost {add|list|del}
# 数据库管理:
lnmp database {add|list|edit|del}
# FTP用户管理:
lnmp ftp {add|list|edit|del|show}
# 已存在虚拟主机添加SSL:
lnmp ssl add
# 删除虚拟主机
chattr -i webroot/.user.ini
rm -rf webroot
④、为MySQL添加可任意连接的root用户
# 通过命令行连接MySQL
mysql -uroot -p
# 执行如下命令
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'mypwd' WITH GRANT OPTION;
mysql> flush privileges;
mysql> exit
⑤、安装邮件组件
 yum -y install sendmail
 service sendmail start
 yum -y install mailx
⑥、安装SSH2扩展
yum -y install git libssh2-devel
git clone https://git.php.net/repository/pecl/networking/ssh2.git
cd ssh2
/usr/local/php7.3.5/bin/phpize
./configure --with-php-config=/usr/local/php7.3.5/bin/php-config
make
make install
echo "extension=ssh2.so">>/usr/local/php7.3.5/etc/php.ini
rm -rf ../ssh2

X、安装Nvm和Node(爬虫工具PyExecJS会用到)

# 安装NVM
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.34.0/install.sh | bash
# 设置环境变量,在~/.zshrc中添加以下内容
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"  # This loads nvm
[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion"
# 使之生效
source ~/.zshrc
# 使用NVM安装LTS版本
nvm install --lts

XI、安装并配置Supervisor

①、安装Supervisor

PS.因为Python2即将被放弃,所以尽量使用Python3版本

 pip3 install supervisor
②、Supervisor组件介绍:
- 1、Supervisord
介绍:Supervisord是Supervisor的服务端程序。
功能:启动Supervisor程序自身,启动Supervisor管理的子进程,响应来自clients的请求,重启闪退或异常退出的子进程,把子进程的stderr或stdout记录到日志文件中,生成和处理Event。

- 2、Supervisorctl
介绍:Supervisorctl是Supervisor的客户端程序。
功能:Supervisorctl有一个类型shell的命令行界面,我们可以利用它来查看子进程状态,启动/停止/重启子进程,获取running子进程的列表等操作,Supervisorctl不仅可以连接到本机上的Supervisord,还可以通过TCP socket连接到远程的Supervisord,Supervisorctl和Supervisord之间的通信,是通过XML-RPC完成的。
③、生成配置文件
echo_supervisord_conf > /etc/supervisord.conf

配置文件详解:

; ;是用来注释的

[unix_http_server]
file=/tmp/supervisor.sock   ; UNIX socket文件,Supervisorctl用XML_RPC和Supervisord通信时会用到【非必须】
;chmod=0700                 ; socket文件的mode,默认是0700【非必须】
;chown=nobody:nogroup       ; socket文件的owner,格式:uid:gid【非必须】
;username=user              ; 使用Supervisorctl管理时认证所需的用户名【非必须】
;password=123               ; 使用Supervisorctl管理时认证所需的密码【非必须】

;[inet_http_server]         ; HTTP服务器,提供Web管理界面【非必须】,若想要使用Web管理,【必须】
;port=127.0.0.1:9001        ; Web管理后台运行的IP和端口,如果开放到公网,需要注意安全性,【非必须】,若想要使用Web管理,【必须】
;username=user              ; 登录Web管理后台的用户名【非必须】,若想要使用Web管理,为提高安全性,【必须】
;password=123               ; 登录Web管理后台的密码【非必须】,若想要使用Web管理,为提高安全性,【必须】

[supervisord]                ; 定义Supervisord服务端参数【必须】
logfile=/tmp/supervisord.log ; 日志文件,默认是 $CWD/supervisord.log【非必须】
logfile_maxbytes=50MB        ; 日志文件大小,超出会生成新的,默认 50MB,如果设成0,表示不限制大小【非必须】
logfile_backups=10           ; 日志文件保留备份数量默认10,设为0表示不限制数量【非必须】
loglevel=info                ; 日志级别,默认info,其它: critical, error, warn, info, debug, trace, or blather【非必须】
pidfile=/tmp/supervisord.pid ; pid 文件路径,默认supervisord.pid【非必须】
nodaemon=false               ; 如果是true,Supervisord进程将在前台运行,默认是false,即后台启动【非必须】
minfds=1024                  ; 可以打开的文件描述符的最小值,默认 1024【非必须】
minprocs=200                 ; 可以打开的进程数的最小值,默认 200【非必须】
;umask=022                   ; 进程创建文件的掩码【非必须】
;user=chrism                 ; 设置一个非root用户,以root用户启动Supervisord之后,可以对Supervisord进行管理【非必须】
;identifier=supervisor       ; Supervisord的标识符,给XML_RPC用的,可以用来标识多个不同的Supervisord服务【非必须】
;directory=/tmp              ; 当Supervisord作为守护进程运行的时候,如果启用该参数,Supervisord会在该目录下执行【非必须】
;nocleanup=true              ; 为false的时候,会在Supervisord启动的时候清除掉之前子进程产生的日志,可以设置为true【非必须】
;childlogdir=/tmp            ; 子进程日志路径为AUTO的时候,子进程日志文件的存放路径,可以通过 python -c "import tempfile;print tempfile.gettempdir()" 查看默认路径【非必须】
;environment=KEY="value"     ; 设置Supervisord进程专属环境变量,可以被子进程继承【非必须】
;strip_ansi=false            ; 是否自动清除子进程日志中的ANSI字符(\n,\t等),默认为false【非必须】

[rpcinterface:supervisor]    ; 开放XML_RPC【必须】
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface

[supervisorctl]      ;Supervisorctl的配置
serverurl=unix:///tmp/supervisor.sock ; Supervisorctl本地连接Supervisord时UNIX socket路径,与前面的[unix_http_server]对应的,默认值是unix:///tmp/supervisor.sock【非必须】
;serverurl=http://127.0.0.1:9001 ; Supervisorctl远程连接Supervisord时TCP socket路径,与前面的[inet_http_server]对应,默认值是http://127.0.0.1:9001【非必须】
;username=chris              ; 参考[unix_http_server]设置,如果[unix_http_server]设置了,需保持一致【非必须】
;password=123                ; 参考[unix_http_server]设置,如果[unix_http_server]设置了,需保持一致【非必须】
;prompt=mysupervisor         ; 输入用户名密码时候的提示符默认supervisor【非必须】
;history_file=~/.sc_history  ; 类似shell中的history,可以用上下键来查找前面执行过的命令,默认是no file,如果想要有这种功能,必须指定一个文件【非必须】

; The sample program section below shows all possible program subsection values.
; Create one or more 'real' program: sections to be able to control them under
; supervisor.

;[program:theprogramname]      ; 子进程管理设置,":"后面的是名字,可以设置多个,一个program就是一个要被管理的进程,开启子进程管理时【必须】
;command=/bin/cat              ; 子进程命令路径,可以带参数,例子:/home/test.py -a 'hello',开启子进程管理时【必须】
;process_name=%(program_name)s ; 进程名,numprocs参数为1时该参数没有实际意义,默认值%(program_name)s即为[program:theprogramname]中的theprogramname【非必须】
;numprocs=1                    ; 启动进程的数目。不为1时,就是进程池的概念,注意process_name的设置,默认为1【非必须】
;directory=/tmp                ; 进程运行前,先切换到这个目录【非必须】
;umask=022                     ; 进程掩码,默认none【非必须】
;priority=999                  ; 子进程启动关闭优先级,优先级低的,最先启动,关闭的时候最后关闭,默认值为999【非必须】
;autostart=true                ; 为true时子进程将在supervisord启动后被自动启动,默认是true【非必须】
;startsecs=1                   ; 子进程启动多少秒后如果状态是running,则我们认为进程启动成功,默认为1【非必须】
;startretries=3                ; 进程启动失败后,最大尝试启动的次数,默认为3,超过3次后,Supervisor将把此进程的状态置为FAIL【非必须】
;autorestart=unexpected        ; 子进程挂掉后自动重启的设置,有三个选项,false,unexpected和true,为false时无论什么情况都不会被自动重启,为unexpected时只有当进程的退出码不在exitcodes范围里才会被自动重启,为true时只要子进程挂掉就会被无条件的重启【非必须】
;exitcodes=0,2                 ; 与上面的autorestart=unexpected设置对应【非必须】
;stopsignal=QUIT               ; 进程停止信号,可以为TERM, HUP, INT, QUIT, KILL, USR1, or USR2等信号,默认为TERM ,当用设定的信号去干掉进程,退出码会被认为是expected【非必须】
;stopwaitsecs=10               ; 我们向子进程发送stopsignal信号至系统返回信息给Supervisord中所等待的最大时间,超过这个时间,Supervisord会向该子进程发送一个强制kill的信号,默认为10秒【非必须】
;stopasgroup=false             ; 当Supervisord管理的子进程本身还有子进程时,如果仅仅终止Supervisord的子进程,该进程的子进程有可能会变成僵尸进程,可以设置这个选项把该子进程的整个进程组都干掉。 设置为true的话,一般killasgroup也会被设置为true。需要注意的是,该选项发送的是stop信号,默认为false【非必须】
;killasgroup=false             ; 和上面的stopasgroup类似,不过发送的是kill信号【非必须】
;user=chrism                   ; 如果Supervisord是root启动,在这里设置这个非root用户,可以用来管理该program,默认不设置【非必须】
;redirect_stderr=true          ; 如果为true,则stderr的日志会被写入stdout日志文件中,默认为false【非必须】
;stdout_logfile=/a/path        ; 子进程的stdout的日志路径,可以指定路径,AUTO,none等三个选项。设置为none时没有日志产生。设置为AUTO将会随机找一个地方生成日志文件,而且当Supervisord重新启动的时候,以前的日志文件会被清空。当 redirect_stderr=true的时候,sterr也会写进这个日志文件【非必须】
;stdout_logfile_maxbytes=1MB   ; 日志文件最大大小,和[supervisord]中定义的一样。默认为50【非必须】
;stdout_logfile_backups=10     ; 和[supervisord]定义的一样。默认10【非必须】
;stdout_capture_maxbytes=1MB   ; 设定capture管道的大小,当值不为0的时候,子进程可以从stdout发送信息,而Supervisor可以根据信息,发送相应的event,默认为0,为0的时候表达关闭管道【非必须】
;stdout_events_enabled=false   ; 设置为ture时当子进程由stdout向文件描述符中写日志的时候,将触发Supervisord发送PROCESS_LOG_STDOUT类型的event,默认为false【非必须】
;stderr_logfile=/a/path        ; stderr的日志路径,当redirect_stderr=true时无效,此时会被写入stdout_logfile的同一个文件中,默认为AUTO【非必须】
;stderr_logfile_maxbytes=1MB   ; 参考以上解释【非必须】
;stderr_logfile_backups=10     ; 参考以上解释【非必须】
;stderr_capture_maxbytes=1MB   ; 参考以上解释,和stdout_capture一样。 默认为0,关闭状态【非必须】
;stderr_events_enabled=false   ; 参考以上解释,默认为false【非必须】
;environment=A="1",B="2"       ; 该子进程的环境变量,和别的子进程是不共享的【非必须】
;serverurl=AUTO                ; 参考以上解释【非必须】


;[eventlistener:theeventlistenername]    ; 与program同样都是Suopervisor启动的子进程,负责订阅Supervisord发送的event,称之为listener了【非必须】
;command=/bin/eventlistener    ; 同program设置相同【非必须】
;process_name=%(program_name)s ; 同program设置相同【非必须】
;numprocs=1                    ; 同program设置相同【非必须】
;events=EVENT                  ; event事件的类型,只有写在这个地方的事件类型,才会被发送【非必须】
;buffer_size=10                ; event队列缓存大小,默认值为10【非必须】
;directory=/tmp                ; 同program设置相同【非必须】
;umask=022                     ; 同program设置相同【非必须】
;priority=-1                   ; 同program设置相同【非必须】
;autostart=true                ; 同program设置相同【非必须】
;startsecs=1                   ; 同program设置相同【非必须】
;startretries=3                ; 同program设置相同【非必须】
;autorestart=unexpected        ; 同program设置相同【非必须】
;exitcodes=0,2                 ; 同program设置相同【非必须】
;stopsignal=QUIT               ; 同program设置相同【非必须】
;stopwaitsecs=10               ; 同program设置相同【非必须】
;stopasgroup=false             ; 同program设置相同【非必须】
;killasgroup=false             ; 同program设置相同【非必须】
;user=chrism                   ; 同program设置相同【非必须】
;redirect_stderr=false         ; 同program设置相同【非必须】
;stdout_logfile=/a/path        ; 同program设置相同【非必须】
;stdout_logfile_maxbytes=1MB   ; 同program设置相同【非必须】
;stdout_logfile_backups=10     ; 同program设置相同【非必须】
;stdout_events_enabled=false   ; 同program设置相同【非必须】
;stderr_logfile=/a/path        ; 同program设置相同【非必须】
;stderr_logfile_maxbytes=1MB   ; 同program设置相同【非必须】
;stderr_logfile_backups=10     ; 同program设置相同【非必须】
;stderr_events_enabled=false   ; 同program设置相同【非必须】
;environment=A="1",B="2"       ; 同program设置相同【非必须】
;serverurl=AUTO                ; 同program设置相同【非必须】


;[group:thegroupname]          ; 为programs分组,在组里面的program就不用一个一个去操作,可以对组名进行统一的操作。 注意:program被划分到组里面之后,Supervisor只会对组进行管理,而不再对组里面的单个program进行管理,使用组操作时【必须】
;programs=progname1,progname2  ; 组成员,用逗号分开,使用组操作时【必须】
;priority=999                  ; 优先级,相对于组和组之间,默认999【非必须】

;[include]
;files = relative/directory/*.ini    ; 需要管理的进程很多的时候,可以把配置信息写到多个文件中,然后include引入,引入多个配置文件时可以使用 空格 分割不同的配置文件

PS.即使是使用默认生成的配置文件也可以直接启动Supervisor,这里提供一份我设置的配置文件(仅供参考):

[unix_http_server]
file=/var/run/supervisor.sock

[inet_http_server]
port=*:9001
username=user
password=password

[supervisord]
logfile=/var/log/supervisord.log
logfile_maxbytes=50MB
logfile_backups=10
loglevel=info
pidfile=/var/run/supervisord.pid
nodaemon=false
minfds=1024
minprocs=200

[rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface

[supervisorctl]
serverurl=unix:///var/run/supervisor.sock

[include]
files = supervisord.d/*

PS.这里使用/etc/supervisord.d文件夹作为Supervisor项目配置目录,在使用时需要创建该目录:

mkdir -p /etc/supervisord.d
④、服务管理
  • 启动Supervisord:

    supervisord -c /etc/supervisord.conf
    
  • 关闭Supervisord:

    supervisorctl shutdown
    
  • 重载:

    supervisorctl reload
    
  • 开机启动方式①:

    • I、在/etc/rc.local中添加命令:

      supervisord -c /etc/supervisord.conf
      
    • II、修改/etc/rc.local执行权限:

      chmod +x  /etc/rc.local
      
  • 开机启动方式②:

    • I、创建服务: vi /usr/lib/systemd/system/supervisord.service:

      [Unit]
      Description=Supervisor
             
      [Service]
      Type=forking
      ExecStart=/usr/local/bin/supervisord
      ExecStop=/usr/local/bin/supervisorctl $OPTIONS shutdown
      ExecReload=/usr/local/bin/supervisorctl $OPTIONS reload
      KillMode=process
      Restart=on-failure
      RestartSec=42s
             
      [Install]
      WantedBy=multi-user.target
      
    • II、使服务生效

      systemctl enable supervisord
      
    • III、查看服务状态

      systemctl status supervisord
      
    • IV、其它命令

      systemctl start supervisord
      systemctl stop supervisord
      systemctl reload supervisord
      
⑤、使用Nginx进行Web管理

Nginx配置文件如下:

server {
    listen 80;
    server_name xx.com;
    location / {
        proxy_http_version 1.1;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_pass http://127.0.0.1:9001$request_uri;
        proxy_redirect off;
  }
}

这样就可以用Web控制Supervisor了,但是web访问时会出现样式错乱,需要将Supervisor的Web资源放到Nginx配置的root目录下,假设这里root目录是/data/wwwroot/supervisor,则首先执行如下命令,得到python的site-packages的目录:

python -c "from distutils.sysconfig import get_python_lib; print(get_python_lib())"

上面我这里的执行结果是:

/usr/lib/python2.7/site-packages

接下来将Supervisor自带的ui界面放到root目录下:

cp -R /usr/lib/python2.7/site-packages/supervisor/ui/* /data/wwwroot/supervisor/

重新刷新页面,就会有基本的样式了。

⑥、项目配置文件

以下是简单的项目配置文件内容(仅供参考):

[program:test]
command=command
user=root
autorstart=true
autorestart=true
startsecs=10
startretries=3
redirect_stderr=true
stdout_logfile=logfile
stderr_logfile=errfile
environment=env

将配置文件放在目录/etc/supervisord.d中,然后重启Supervisord即可

⑦、使用Supervisorctl管理项目

Supervisorctl启动时需要指定与Supervisord使用同一份配置文件,否则与Supervisord一样按照顺序查找配置文件,常用命令如下: - 启动Supervisorctl:

supervisorctl -c /etc/supervisord.conf

使用上面的命令会进入Supervisorctl的shell界面 - 查看项目状态:

supervisorctl status

在shell中直接输入后面的命令即可 - 启动项目test:

supervisorctl start test
  • 关闭项目test:

    supervisorctl stop test
    
  • 重启项目test:

    supervisorctl restart test
    

其它命令及用法可参考官方介绍Running Supervisorctl

本文总结的工具安装就到此为止,以后还有需要添加的再酌情添加。