Linux 使用记录

 
作为web程序员,该掌握的 linux 命令有哪些,稍微高级点的? - 刘志军的回答 - 知乎 
答案中提到一本书:《The Linux Command Line》,中文版叫《快乐的 Linux 命令行》
 
 
以下为查看 tomcat 日志(在 Jenkins 上构建项目时)的命令:
1、cd /usr/local/apache-tomcat-8.0.47/logs/(进入日志文件夹)
2、ll -rthl(查看最近更新的文件的详细信息)
(注:相关命令有 ll、ls,可参考:https://www.cnblogs.com/zhaosunwei/p/7069029.html
3、tail -f catalina.out ,查看日志内容(开始输入日志信息)
4、ctrl+c:tail命令,停止输出日志信息
 
vi 文件之后,按 i 进入编辑模式,按 esc 键退出编辑模式,进入命令模式
 
退出 vim 编辑器(注意各种退出命令之前都有一个冒号):
按Esc键,退出编辑模式,进入命令模式。然后可以键入
>:q to quit(short for:quit)
>:q!退出而不保存(短接:退出!)
>:wq写和退出(认为写和退出)
>:wq!即使文件只有读取权限(如果文件没有写入权限:强制写入),也可以写入和退出。
>:x写和退出(类似于:wq,但如果没有更改就不会写)
>:qa to quit all(缩写:quitall)
​
当您按:,a:将出现在屏幕的底部。
​
或者您可以按Esc ZZ(Esc Shift Z Shift Z)写入/保存文件被更改,然后退出。
​
或者如果你不想保存更改,可以使用ZQ。
​
Vim有广泛的帮助,所以键入Esc:helpReturn,你会有你的所有答案,甚至一个整洁的教程。
注:如果在没有进入编辑模式的情况下(即,只是 vi 文件,没有按 i,则无需按 esc 键再按 :q! 键退出了)
 
exit   退出当前终端会话(断开 xshell 和服务器的连接)
 
cd ..    返回上级目录
注意:cd 和 .. 之间有一个空格
 
定位 tomcat 中 Catalina.log 中定位错误信息的方法:
1、定位指定异常(具体到哪一行)
2、查询异常附近的信息
https://blog.csdn.net/u010648555/article/details/78073104(内容和排版都非常好)
 
输出 catalina.out 文件中,6132300 行及之后的所有数据到 tmp 文件夹的 0508.txt 文件
cat -n catalina.out|tail -n +6132300  > /tmp/0508.txt
注:
> 表示将信息输出
/tmp 中的 / 表示根目录
/tmp 文件夹是系统自带的
0508.txt 文件时新建的(名字随便起)
 
linux 下进程、端口相互查看方法:
通过进程名查端口:
1、先查看进程pid
ps -ef | grep 进程名
​
2、通过pid查看占用端口
netstat -nap | grep 进程pid

 

通过端口查进程:
<wiz_code_mirror>
netstat -nap | grep 端口号

 

tab 键有补位的功能
 
pwd 查看当前目录
 
文件查找 文件搜索 find:
例如:
find / .name 'nginx.conf'
注:一定要用英文引号,否则查不到,且不报任何错误
 


 
jenkins 上登记项目的配置信息中的 execute shell,我自己加了一些注释:
// jenkins 已经连接了 gitlab,并将代码打包
// scp 跨服务器复制,将打包后的代码,复制到目标服务器的特定位置
scp -r /root/.jenkins/workspace/xx_xx_system/target/xx-xx-system-1.0.0-SNAPSHOT.jar root@xx.xx.xx.xxx:/usr/wyl/xx-xx-system
// ssh 切换(操作的)服务器               v/null 2>&1 存疑   远程执行的内容在“<< eeooff ” 至“ eeooff ”之间,在远程机器上的操作就位于其中
ssh root@xx.xx.xx.xxx> /dev/null 2>&1 << eeooff 
// 进入文件夹
cd /usr/wyl/xx-xx-system
// 查原 jar 包进程
pid=\`ps -ef | grep /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar | grep -v grep | awk '{print \$2}'\`
// 判断,若原始进程存在,则kill掉,重新启动
if [ -n "\$pid" ];
then
    // 打印(echo)进程名称
    echo "kill -9 pid:" \$pid
    kill -9 \$pid
// 判断结束标识
fi 
// 给新加的jar包,赋所有权限(777)
chmod 777 /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar
// java -jar 启动 jar 包   使用 nohup + 命令 +  $ 的方式使 jar 包能一直在后台运行,否则关闭操作窗口之后,该进程会停止。其中,nohup 是不挂起的意思
nohup java -jar /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar >/dev/null 2>&1 &
// 查看进程,确定是否启动成功
npid=\`ps -ef | grep /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar | grep -v grep | awk '{print \$2}'\`
// 判断,若新进程存在
if [ -n "\$npid" ];
then
    // 打印(echo)进程名称
    echo "new pid:" \$npid
fi
// 在结束
远程命令“eeooff”之前,加 exit 退出远程节点

exit
eeooff

 

关于 >/dev/null 2>&1 比较好的文章:
关于 eeooff 在以下文章的一开始有比较好的解释:
 
 
最终在服务器的xx项目的同目录下,创建了 restart.sh 文件,内容如下:(更新此段代码,错代码保存    \$2 中的 \ 不应该存在    if [ -n "\$pid" ]?    重视机器说的话   知道有 xshell 编程之后,心理就没有陌生感了,因为学过其他的编程语言)
cd /usr/wyl/xx-xx-system
pid=\`ps -ef | grep /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar | grep -v grep | awk '{print \$2}'\`
if [ -n "\$pid" ];
then
   echo "kill -9 pid:" \$pid
   kill -9 \$pid
fi
chmod 777 /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar
nohup java -jar /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar >/dev/null 2>&1 &
npid=\`ps -ef | grep /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar | grep -v grep | awk '{print \$2}'\`
if [ -n "\$npid" ];
then
   echo "new pid:" \$npid
fi

 

 
正确的脚本代码:
cd /usr/wyl/xx-xx-system
pid=$(ps -ef | grep /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar | grep -v grep | awk '{print $2}')
if [ -n "\$pid" ];
then
   echo "kill -9 pid:" $pid
   kill -9 $pid
fi
chmod 777 /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar
nohup java -jar /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar >/dev/null 2>&1 &
npid=$(ps -ef | grep /usr/wyl/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar | grep -v grep | awk '{print $2}')
if [ -n "\$npid" ];
then
   echo "new pid:" $npid
fi
迁移服务器之后更新的脚本:
cd /usr/local/xx-xx-system
pid=$(ps -ef | grep /usr/local/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar | grep -v grep | awk '{print $2}')
if [ -n "\$pid" ];
then
    echo "kill -9 pid:" $pid
    kill -9 $pid
fi
chmod 777 /usr/local/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar
nohup java -jar /usr/local/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar >/dev/null 2>&1 &
npid=$(ps -ef | grep /usr/local/xx-xx-system/xx-xx-system-1.0.0-SNAPSHOT.jar | grep -v grep | awk '{print $2}')
if [ -n "\$npid" ];
then
    echo "new pid:" $npid
fi
用新的 jar 包覆盖原 jar 包之后,只需执行以下命令即可:
sh /usr/local/xx-xx-system/restart.sh

 

 
在 idea 中,操作步骤:
重新部署 spring boot 项目(此处针对项目 xx-xx-system)
1、打包(Maven:clean、package),生成新的 jar 文件
2、将项目 xx_xx_system 的 target 目录下的 xx-xx-system-1.0.0-SNAPSHOT.jar 文件拷贝到以下位置,将原来的 jar 包覆盖
(Tools → Deployment → Browse Remote Host)
3、在服务器执行命令:(Tools → Start SSH session → 可信主服务器)
sh /usr/wyl/xx-xx-system/restart.sh
以执行脚本 restart.sh,重启服务器
 
 
 
 

 
对于 spring boot 项目,在服务器上使用 shell 命令重启 jar 包:
 
[root@iz2zec3dge6rwzdxgdl48vz ~]# ps -ef|grep java
root      2429     1  0 Sep26 ?        00:22:16 java -jar yy-yy-manage-1.0.0-SNAPSHOT.jar
root      5096  5072  0 17:20 pts/3    00:00:00 grep --color=auto java
root      6026     1  0 Sep28 ?        00:19:07 java -jar aa-aa-manage-1.0.0-SNAPSHOT.jar
root     21019     1  0 Oct10 ?        00:06:54 java -jar xx-xx-system-1.0.0-SNAPSHOT.jar
root     22118     1  0 Sep17 ?        00:32:27 java -jar aa-bb-server-1.0.0-SNAPSHOT-1.jar
root     22167     1  0 Sep17 ?        00:32:24 java -jar aa-bb-server-1.0.0-SNAPSHOT-2.jar
[root@iz2zec3dge6rwzdxgdl48vz ~]# kill -9 21019
[root@iz2zec3dge6rwzdxgdl48vz ~]# ps -ef|grep java
root      2429     1  0 Sep26 ?        00:22:16 java -jar yy-yy-manage-1.0.0-SNAPSHOT.jar
root      5099  5072  0 17:21 pts/3    00:00:00 grep --color=auto java
root      6026     1  0 Sep28 ?        00:19:07 java -jar aa-aa-manage-1.0.0-SNAPSHOT.jar
root     22118     1  0 Sep17 ?        00:32:27 java -jar aa-bb-server-1.0.0-SNAPSHOT-1.jar
root     22167     1  0 Sep17 ?        00:32:24 java -jar aa-bb-server-1.0.0-SNAPSHOT-2.jar
[root@iz2zec3dge6rwzdxgdl48vz ~]# cd /usr/wyl
[root@iz2zec3dge6rwzdxgdl48vz wyl]# ll
total 1808
drwxr-xr-x 4 root root    4096 Sep 28 18:23 aa-aa-manage
drwxr-xr-x 3 root root    4096 Sep 26 11:31 yy-yy-manage
drwxr-xr-x 3 root root    4096 Oct  8 10:59 xx-xx-system
drwxr-xr-x 3 root root    4096 Oct 15 14:58 java
drwxr-xr-x 4 root root    4096 Sep  5 11:25 mysql
drwxr-xr-x 4 root root    4096 Sep  6 17:00 private_cloud
drwxr-xr-x 5 root root    4096 Sep  7 16:06 aa_bb_server
drwxr-xr-x 4 root root    4096 Oct 15 16:15 redis
drwxrwxr-x 6 root root    4096 Oct 15 16:16 redis-4.0.7
-rw-r--r-- 1 root root 1729488 Oct 15 16:13 redis-4.0.7.tar.gz
drwxr-xr-x 3 root root    4096 Sep  5 08:47 ST_Get_UUID_Tool_Linux
-rw-r--r-- 1 root root   76923 Sep  4 11:16 ST_Get_UUID_Tool_Linux.zip
[root@iz2zec3dge6rwzdxgdl48vz wyl]# cd xx-xx-system/
[root@iz2zec3dge6rwzdxgdl48vz xx-xx-system]# ll
total 49668
-rwxrwxrwx 1 root root 46802373 Oct 15 16:38 xx-xx-system-1.0.0-SNAPSHOT.jar
drwxr-xr-x 3 root root     4096 Oct 15 10:43 logs
-rw------- 1 root root  4044093 Oct 15 17:20 nohup.out
[root@iz2zec3dge6rwzdxgdl48vz xx-xx-system]# nohup java -jar xx-xx-system-1.0.0-SNAPSHOT.jar &
[1] 5102
[root@iz2zec3dge6rwzdxgdl48vz xx-xx-system]# nohup: ignoring input and appending output to ‘nohup.out’
​
[root@iz2zec3dge6rwzdxgdl48vz xx-xx-system]# 
[root@iz2zec3dge6rwzdxgdl48vz xx-xx-system]# 
[root@iz2zec3dge6rwzdxgdl48vz xx-xx-system]# ps -ef|grep java
root      2429     1  0 Sep26 ?        00:22:16 java -jar yy-yy-manage-1.0.0-SNAPSHOT.jar
root      5102  5072 99 17:22 pts/3    00:00:37 java -jar xx-xx-system-1.0.0-SNAPSHOT.jar
root      5149  5072  0 17:22 pts/3    00:00:00 grep --color=auto java
root      6026     1  0 Sep28 ?        00:19:07 java -jar aa-aa-manage-1.0.0-SNAPSHOT.jar
root     22118     1  0 Sep17 ?        00:32:27 java -jar aa-bb-server-1.0.0-SNAPSHOT-1.jar
root     22167     1  0 Sep17 ?        00:32:24 java -jar aa-bb-server-1.0.0-SNAPSHOT-2.jar
[root@iz2zec3dge6rwzdxgdl48vz xx-xx-system]# 

 

 

 

nginx

 
查找 nginx.conf 文件的位置:
find / .name 'nginx.conf'
 
修改 nginx.conf 文件之后,检查该配置文件是否正确:
/usr/local/nginx/sbin/nginx -t -c /usr/local/nginx/conf/nginx.conf
参考:
介绍下检查nginx配置文件是否正确的方法,在nginx查检配置文件,主要是用nginx -t命令,
如何检查配置是否正确呢?用nginx -t命令就好了。
一、nginx的几个命令参数Nginx 安装后只有一个程序文件,本身并不提供各种管理程序,它是使用参数和系统信号机制对 Nginx 进程本身进行控制的。
Nginx 的参数包括:可以这样使用 /usr/local/nginx/sbin/nginx  -参数
-c <path_to_config>:使用指定的配置文件而不是 conf 目录下的 nginx.conf 。
-t:测试配置文件是否正确,在运行时需要重新加载配置的时候,此命令非常重要,用来检测所修改的配置文件是否有语法错误。
-v:显示 nginx 版本号。
-V:显示 nginx 的版本号以及编译环境信息以及编译时的参数。
二、检测新的conf文件
测试当前nginx.conf文件是否正确,使用命令:
复制代码 代码示例:
[root@localhost]/usr/local/nginx/conf# /usr/local/nginx/sbin/nginx -t -c /usr/local/nginx/conf/nginx.conf
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is oknginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful 
​
得到如此结果,说明新conf文件没有错误。
如果有错,它会提示在哪行出了错,再修改错误即可。
​
作者:金星show
链接:https://www.jianshu.com/p/26d562bf69bb
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

 

nginx 启动、重启、关闭命令:
 
nginx 启动命令:
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
 
查看 nginx 进程(其中 master 为主进程):
ps -ef|grep nginx
 
端口号,要在阿里云添加安全组
 
配置文件新添内容:
<wiz_code_mirror>
# 该段为新加部分,为了给xx系统的图片做代理
   server {
        listen       9016;
        server_name  xx.xx.xx.xxx;
        root         /xx_xx_system/upload_file;
​
        location / {
        }
​
        error_page 404 /404.html;
            location = /40x.html {
        }
​
        error_page 500 502 503 504 /50x.html;
            location = /50x.html {
        }
   }

 

 

posted @ 2018-12-05 11:50  stoneBlog  阅读(287)  评论(0编辑  收藏  举报