web服务部署及运维笔记(pm2,git等)

本次笔记为linux环境下node.js

一、项目管理

1、PM2

安装PM2

npm install pm2 -g

用PM2运行node.js项目

pm2 start app.js

查询目前所有项目情况

pm2 list

查询指定项目,如项目 app

pm2 show app

2、设置PM2开机自运行项目

生成开机启动 pm2 服务的配置文件

运行:

pm2 startup

先用pm2 start 加路径,启动项目,使项目在pm2 list中可见

保存项目命令

pm2 save

即可下次开机自动运行。

重启服务

pm2 restart 服务名或ID

重启所有服务

pm2 restart all

删除服务

pm2 delete 服务名或ID

3、PM2日志管理

查询日志

pm2 logs

pm2 日志文件位置:/root/.pm2/logs

pm2日志分割插件 pm2-logrotate

安装插件

pm2 install pm2-logrotate

安装成功后 通过pm2 list 可以查看

通过命令设置格式,命令参数如下

pm2 set pm2-logrotate:{paramName} {value}

命令设置具体的参数,支持的参数有:

l Compress:是否通过gzip压缩日志

l max_size:单个日志文件的大小

l retain:保留的日志文件个数,比如设置为10,那么在日志文件达到10个后会将最早的日志文件删除掉

l dateFormat:日志文件名中的日期格式,默认是YYYY-MM-DD_HH-mm-ss,注意是设置的日志名+这个格式,如设置的日志名为abc.log,那就会生成abc_YYYY-MM-DD_HH-mm-ss.log名字的日志文件

l rotateModule:把pm2本身的日志也进行分割  设置true不会对默认的日志分割,设置false会对默认日志进行分割(默认日志和新设置的日志只能生效一种)

l workerInterval:设置启动几个工作进程监控日志尺寸,最小为1

rotateInterval:设置强制分割,默认值是0 0 * * *,意思是每天晚上0点分割

0 0 * * *  对应 分钟 小时 日 月 周几(0-7),*表示通配符

16 * * * *  表示每小时第16分钟分割日志

0 16 * * * 表示每天16点0分分割日志

配置 例子

pm2 set pm2-logrotate:max_size 10M

pm2 set pm2-logrotate:retain 10

pm2 set pm2-logrotate:compress false

pm2 set pm2-logrotate:dateFormat YYYY-MM-DD_HH-mm-ss

pm2 set pm2-logrotate:workerInterval 10

pm2 set pm2-logrotate:rotateInterval 10 * * * *

pm2 set pm2-logrotate:rotateModule true

配置完成后要重启pm2

pm2 restart all

查看配置

pm2 conf pm2-logrotate

 

二、代码维护

1、git pull 命令用于从远程获取代码并合并本地的版本

git pull的时候发生冲突的解决方法之“error: Your local changes to the following files would be overwritten by merge”

目前git的报错提示已经相关友好了,可以直观的发现,这里可以通过commit的方式解决这个冲突问题,另外还可以根据实际情况使用另外两种解决方法:

方法一、stash

1 git stash
2 git commit
3 git stash pop

接下来diff一下此文件看看自动合并的情况,并作出相应修改。

git stash: 备份当前的工作区的内容,从最近的一次提交中读取相关内容,让工作区保证和上次提交的内容一致。同时,将当前的工作区内容保存到Git栈中。
git stash pop: 从Git栈中读取最近一次保存的内容,恢复工作区的相关内容。由于可能存在多个Stash的内容,所以用栈来管理,pop会从最近的一个stash中读取内容并恢复。
git stash list: 显示Git栈内的所有备份,可以利用这个列表来决定从那个地方恢复。
git stash clear: 清空Git栈。此时使用gitg等图形化工具会发现,原来stash的哪些节点都消失了。

方法二、放弃本地修改,直接覆盖

1 git reset --hard
2 git pull

 

三、mysql允许特定IP远程访问

mysql -u root -p

use mysql;

查询用户表命令:select User,authentication_string,Host from user;

接下来就是最重要的部分了:

1. GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456'

这里的123456为你给新增权限用户设置的密码,%代表所有主机,也可以具体到你的主机ip地址

2.flush privileges;          这一步一定要做,不然无法成功! 这句表示从mysql数据库的grant表中重新加载权限数据

因为MySQL把权限都放在了cache中,所以在做完更改后需要重新加载。

执行完这两步,再次查询用户表命令:select  User,authentication_string,Host from user

 

用update 修改root密码时报错,解决办法:

ALTER USER 'root'@'localhost' IDENTIFIED BY '123456'

未经允许不得转载:生于七零年代 » web服务部署及运维笔记(pm2,git等)

赞 (38) 打赏

评论

4+9=

觉得文章有用就打赏一下文章作者

微信扫一扫打赏