文章目录
linux
基础
cp -r file1 file 2
cp -r gtm-server/ ../gtm-server
sudo chown -R tomcat:tomcat ./base_hwl_10010/#给用户授权目录
mkdir -p /usr/webser/springboot#递归创建目录
#新增用户,授权目录
useradd tomcat
passwd tomcat
chown -R tomcat.tomcat /usr/webser/
tar -xvf xxx.tar.gz
tail
最常用的tail -f,一般用于查看日志
tail -300f /usr/webser/logs/test.log #倒数300行并进入实时监听文件写入模式
vi
log查看:esc :v/关键字/d #关键字查找
set number
top
链接
查看系统的CPU、内存、运行时间、交换分区、执行的线程等信息
c:查看详细信息
shift+M:按内存排序,排查内存问题
shift+H:按cpu排序,排查cpu问题
free
free -m #查看内存使用信息
iostat
iostat -xd 1#查看io信息
ps
查看进程
ps -ef|grep tomcat
ps -aux 看运行的进程
kill 进程号 结束进程
df/du
查看服务器存储
df -h 查看服务器整体存储
du -h查看文件目录存储
fdisk -l 查看分区情况
:>xxx.log 清空文件内容
du 加上 --max-depth=1 就可以只显示当前目录
netstat
查看端口连接数
netstat -nat|grep -i "12100"|wc -l
netstat -anp | more #查看端口
netstat -anl | grep "80" #查看端口是否被占用
scp
scp /usr/data/test.txt root@192.168.11.12:/usr/data/ #文件远程复制
scp -r local_folder remote_username@remote_ip:remote_folder #复制目录
脚本执行
#a 新建脚本
vi loghttp.sh
#!/bin/bash
for((i=1;i<=100000;i++));
do
date >> netlog;
netstat -nat|grep -i "80"|wc -l >> netlog;
sleep 1s;
done
#b 加权限
chmod u+x loghttp.sh
#c 后台运行
./loghttp.sh &
免密登录
#1设置邮箱
git config --global user.name "xuhaiyan"
git config --global user.email "haiyan.xu.vip@gmail.com"
#2 生成key
ssh-keygen -t rsa -C "123456@qq.com"
#3把自己电脑id_rsa.pub的sshkey追加到linux服务器
vi ~/.ssh/authorized_keys
#或者使用脚本自动追加进去
#4验证登录
ssh tomcat@host
ssh tomcat@116.62.11.8
ssh jqkl@27.150.187.215
#注意
sshd为了安全,对属主的目录和文件权限有所要求。如果权限不对,则ssh的免密码登陆不生效。
用户目录权限为 755 或者 700,就是不能是77x。
.ssh目录权限一般为755或者700。
rsa_id.pub 及authorized_keys权限一般为644
rsa_id权限必须为600
jdk定位
[root@iZ2ze9uuc43mja8vg9ytemZ /]# which java
/usr/bin/java
[root@iZ2ze9uuc43mja8vg9ytemZ /]# ls -lrt /usr/bin/java
lrwxrwxrwx 1 root root 22 1月 4 11:24 /usr/bin/java -> /etc/alternatives/java
[root@iZ2ze9uuc43mja8vg9ytemZ /]# ls -lrt /etc/alternatives/java
lrwxrwxrwx 1 root root 46 1月 4 11:24 /etc/alternatives/java -> /usr/lib/jvm/jre-1.7.0-openjdk.x86_64/bin/java
[root@iZ2ze9uuc43mja8vg9ytemZ /]#
[root@iZ2ze9uuc43mja8vg9ytemZ /]#
[root@iZ2ze9uuc43mja8vg9ytemZ /]#
[root@iZ2ze9uuc43mja8vg9ytemZ /]# cd /usr/lib/jvm
[root@iZ2ze9uuc43mja8vg9ytemZ jvm]# ls
java java-1.7.0 java-1.7.0-openjdk-1.7.0.121.x86_64 java-1.7.0-openjdk.x86_64 java-openjdk jre jre-1.7.0 jre-1.7.0-openjdk.x86_64 jre-openjdk
[root@iZ2ze9uuc43mja8vg9ytemZ jvm]#
彻底卸载(以mysql为例)
#1、使用以下命令查看当前安装mysql情况,查找以前是否装有mysql
rpm -qa|grep -i mysql
#显示之前安装了:
MySQL-client-5.5.25a-1.rhel5
MySQL-server-5.5.25a-1.rhel5
#2、停止mysql服务、删除之前安装的mysql
rpm -ev MySQL-client-5.5.25a-1.rhel5
rpm -ev MySQL-server-5.5.25a-1.rhel5
#如果提示错误
rpm -e --noscripts MySQL-client-5.5.25a-1.rhel5
#3、查找之前老版本mysql的目录、并且删除老版本mysql的文件和库
find / -name mysql
#查找结果如下:
find / -name mysql
/var/lib/mysql
/var/lib/mysql/mysql
/usr/lib64/mysql
#删除对应的mysql目录
rm -rf /var/lib/mysql
rm -rf /var/lib/mysql
rm -rf /usr/lib64/mysql
#卸载后/etc/my.cnf不会删除,需要进行手工删除
rm -rf /etc/my.cnf
#4、再次查找机器是否安装mysql
rpm -qa|grep -i mysql
其他
linux的ssh客户端登录端口是22,如果要kill掉远程登录则查询22端口的连接
破解密码,在系统启动的引导界面,按e进入,选第二个按e在进入,然后按1,返回按b,进入单用户界面修改密码
常见问题
yum安装出现问题时,可能是域yum的问题,升级一下
yum clean all
rpm --rebuilddb
yum update
还不行的话看提示 将xxxxxxx-xxxxx-xxxx.x86_64卸载掉: yum remove xxxxx-xxxxx-xxxxxxx.x86_64
java
vmstat
vmstat 1 #查看虚拟机状态信息
jstack
#解决cpu超高问题,找到出问题的线程id,然后使用jstack命令把该线程的日志输出到文件
#然后把线程id 16进制化,去日志查找
jstack -l pid
jps
jps -v #查看java进程
jmap
jmap -heap pid#查看进程堆信息
jstat
jstat -gc pid#查看进程gc信息