在 web 应用部署到线上后,需要保证应用一直处于运行状态,在遇到程序异常、报错等情况,导致 web 应用终止时,需要保证程序可以立刻重启,继续提供服务。
所以,就需要一个工具,时刻监控 web 应用的运行情况,管理该进程。
Supervisor 就是解决这种需求的工具,可以保证程序崩溃后,重新把程序启动起来等功能。
Supervisor 是一个用 Python 写的进程管理工具,可以很方便的用来在 UNIX-like 系统(不支持 Windows)下启动、重启(自动重启程序)、关闭进程(不仅仅是 Python 进程)。
Supervisor 是一个 C/S 模型的程序,supervisord 是 server 端,supervisorctl 是 client 端
supervisor.conf文件是supervisor配置文件,一般在/etc/目录下,这个配置文件的最后会有一段引入具体每个进程的配置文件代码,即在supervisord.d目录下.ini后缀的文件。
supervisord -c supervisor.conf //启动supervisordsupervisor reload //重新加载配置文件我们可以看到具体每个进程的配置:
程序配置:
[program:app] ; 程序名称,在 supervisorctl 中通过这个值来对程序进行一系列的操作autorestart=True ; 程序异常退出后自动重启autostart=True ; 在 supervisord 启动的时候也自动启动redirect_stderr=True ; 把 stderr 重定向到 stdout,默认 falseenvironment=PATH="/home/app_env/bin" ; 可以通过 environment 来添加需要的环境变量,一种常见的用法是使用指定的 virtualenv 环境command=python server.py ; 启动命令,与手动在命令行启动的命令是一样的user=ubuntu ; 用哪个用户启动directory=/home/app/ ; 程序的启动目录stdout_logfile_maxbytes = 20MB ; stdout 日志文件大小,默认 50MBstdout_logfile_backups = 20 ; stdout 日志文件备份数; stdout 日志文件,需要注意当指定目录不存在时无法正常启动,所以需要手动创建目录(supervisord 会自动创建日志文件)stdout_logfile = /data/logs/usercenter_stdout.logsupervisorctl 是 supervisord 的命令行客户端工具,使用的配置和 supervisord 一样,这里就不再说了。下面,主要介绍 supervisorctl 操作的常用命令:
输入命令 supervisorctl 进入 supervisorctl 的 shell 交互界面(还是纯命令行),就可以在下面输入命令了。
我们可以输入help看看都有哪些命令
help # 查看帮助status # 查看程序状态stop program_name # 关闭 指定的程序start program_name # 启动 指定的程序restart program_name # 重启 指定的程序tail -f program_name # 查看 该程序的日志update # 重启配置文件修改过的程序(修改了配置,通过这个命令加载新的配置)nginx配置文件放在nginx.conf文件,一般位于/etc/nginx目录下面。
在nginx.d目录下面我们可以配置自己应用的nginx服务。
nginx指定文件路径有两种方式root和alias
root与alias主要区别在于nginx如何解释location后面的uri,这会使两者分别以不同的方式将请求映射到服务器文件上。
root的处理结果是:root路径+location路径
alias的处理结果是:使用alias路径替换location路径
alias是一个目录别名的定义,root则是最上层目录的定义。
还有一个重要的区别是alias后面必须要用“/”结束,否则会找不到文件的。。。而root则可有可无~~
注意:
使用alias时,目录名后面一定要加"/"。alias在使用正则匹配时,必须捕捉要匹配的内容并在指定的内容处使用。alias只能位于location块中。(root可以不放在location中)查看nginx.conf配置,Resolver值是访问端口,当你在本地启nginx服务测试的时候,将这个nginx.conf文件里面的Resolver值改为127.0.0.1,之后就可以在浏览器输入localhost:80访问到你的nginx代理的内容
vi /etc/nginx/nginx.conf
查看自己配置的nginx
vi /etc/nginx/conf.d/******.conf
查看nginx日志,这个是配置在`******.conf`里面的,不同的配置会不一样
cat /opt/logs/nginx_access.log cat /opt/logs/nginx_error.logrsync一款快速增量备份工具 Remote Sync,远程同步 支持本地复制,或者与其他SSH、rsync主机同步。
1. 单个主机本地之间的数据传输
2. 借助rcp, ssh等通道来传输数据
3. 以守护进程(socket)的方式传输数据(需要服务端客户端配合, centos中自带了客户端
scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且scp传输是加密的。可能会稍微影响一下速度。当你服务器硬盘变为只读 read only system时,用scp可以帮你把文件移出来。另外,scp还非常不占资源,不会提高多少系统负荷,在这一点上,rsync就远远不及它了。虽然 rsync比scp会快一点,但当小文件众多的情况下,rsync会导致硬盘I/O非常高,而scp基本不影响系统正常使用。
1.命令格式:
scp [参数] [原路径] [目标路径]
2.命令功能:
scp是 secure copy的缩写, scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令。linux的scp命令可以在linux服务器之间复制文件和目录。
3.命令参数:
-1 强制scp命令使用协议ssh1 -2 强制scp命令使用协议ssh2 -4 强制scp命令只使用IPv4寻址 -6 强制scp命令只使用IPv6寻址 -B 使用批处理模式(传输过程中不询问传输口令或短语) -C 允许压缩。(将-C标志传递给ssh,从而打开压缩功能) -p 保留原文件的修改时间,访问时间和访问权限。 -q 不显示传输进度条。 -r 递归复制整个目录。 -v 详细方式显示输出。scp和ssh(1)会显示出整个过程的调试信息。这些信息用于调试连接,验证和配置问题。 -c cipher 以cipher将数据传输进行加密,这个选项将直接传递给ssh。 -F ssh_config 指定一个替代的ssh配置文件,此参数直接传递给ssh。 -i identity_file 从指定文件中读取传输时使用的密钥文件,此参数直接传递给ssh。 -l limit 限定用户所能使用的带宽,以Kbit/s为单位。 -o ssh_option 如果习惯于使用ssh_config(5)中的参数传递方式, -P port 注意是大写的P, port是指定数据传输用到的端口号 -S program 指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项。