本次笔记为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等)