1,安装vim以后把vim中的tab键设置为4个空格
vim ~/.vimrc一下,如果没有会创建新的, 然后添加下面两行:
set ts=4
set expandtab
如果第二行内容是noexpandtab,就把noexpandtab改为expandtab
2,ssh和scp
ssh center@ip -p 22 ssh链接远程主机
scp -P 22 center@ip :~/test.txt . 把远程主机上的~/test.txt下载到本地当前目录
scp ~/下载/CMake_Practice.pdf center@ip:~/公共的/daqing-temp 把本地~/下载/CMake_Practice.pdf上传到远程主机上的~/公共的/daqing-temp文件夹内,不用指定端口哦
tar -xzvf daqing.tar.gz 解压daqing.tar.gz到当前文件夹
tar -czvf daqing.tar.gz etc 压缩当前文件夹下的etc文件夹以及其子文件夹为daqing.tar.gz
3,lampp ubuntu环境进入mysql:
mysql -u root -p
或者
[ root@ha ~]# cd /opt/lampp/bin
[ root@ha bin]# ./mysql –uroot –p123456
4,后台运行
个人认为前后台程序有两种:
1),程序的运行与否和终端相关:终端关闭,则程序挂掉。这类程序一般包括:command;command &;
#!coding=utf-8 #同一个终端内,程序也有前后台运行之分 command #这是前台程序,程序直接在命令后返回运行状态和结果 command & #这是后台程序,程序中如果有类似print之类的控制台输出语句,依然返回到本终端,很有可能造成的结果就是,它不断返回,你一边不断尝试输入命令,基本上就是看你和电脑哪个更快了。 #同一个终端内的程序,前后台如何转换: """ 1,运行的时候最后面加“ &” 2,ctrl 加 z,把当前程序挂到后台,并且中止程序运行。此时终端会返回你一个job号码加进程号,如果你想让它后台继续运行,就用:bg %job号码(挂到后台后仍然会出现人和电脑比手速的问题),如果你想让它来前台运行,那就用:fg %job号码。 """ #如果你想直接停掉他们,直接关终端或者对前台程序做ctrl c就可以了
开启或者关闭 后台运行的常用命令:
ctrl + z 可以将一个正在前台执行的命令放到后台,并且暂停 jobs 查看当前有多少在后台运行的命令 fg 将后台中的命令调至前台继续运行 如果后台中有多个命令,可以用 fg %n将选中的命令调出,n是通过jobs命令查到的后台正在执行的命令的序号(不是pid),经常是1,2,3,这样的简单数字。fg后面不加任何东西的默认意思是:fg %1,把后台运行的第一个程序调到前台来继续跑 bg 将一个在后台暂停的命令,变成继续执行 如果后台中有多个命令,可以用bg %n将选中的命令调出,%n是通过jobs命令查到的后台正在执行的命令的序号(不是pid)
2),程序的运行与否和终端不相干:终端关闭,程序依然运行,这类程序的纯后台程序。
#纯后台进程 nohup command &; #使用所有打印到控制台的标准输出都放到当前文件夹下的output.out中去(如果没有指定的话),然后把程序放到后台继续执行,不和终端有任何绑定。顺带一提,就算退出账户这个程序也不会停止哦 #指定nohu的输出: nohup command > myout.file 2>&1 解释一下,2>&1的意思是标准输出和标准错误都重定向到myout.file中 screen #sudo apt-get screen直接安装就行了 #基础用法:screen -S name 新建一个叫name的虚拟终端,并且登录进去,此时,里面运行的任何程序都是在虚拟终端内部的,不会关闭。运行完一堆程序以后,screen -d name 离开name这个终端。screen -r name 重连name这个终端。screen -ls看看有几个虚拟终端;链接上screen虚拟窗口以后输入exit就关闭并且退出screen虚拟窗口了
3,个人比较常用的命令是:
sudo nohup python ./脚本.py>nohup.out 2>&1 &
意思是,用root权限运行脚本。并且把标准错误和标准输出保存到nohup.out中,放到后台运行起来。
但是有两个点需要十分注意,
a,有关sudo,如果系统需要提示你输入密码,在nohup的状态下你是无法收到系统提示的,所以程序根本跑不起来,解决方法是,先执行随意的sudo命令,然后再用sudo命令加上nohup
b,有关nohup.out,如果你写个while循环,每隔1秒钟输出一个数字到nohup.out中(自定义的文件需要注意是否有写入的权限),那么过了5秒以后,你肯定看不到5个数字,只有ignoring input的字样,为啥?这不代表你程序错了,个人猜测nohup具有输出策略,并不是每个字符串一生成就立马写到文件中去,而是程序执行完,或者遇到报错信息,或者到一定量,或者一定时间(细节不知)才会统一写进去。so,暂时看不到里面的内容不代表你错了。
4,关机
常用的关机:
sudo shutdown #一分钟内广播,清空缓存,然后一分钟时间一到就关机
sudo shutdown -h now #shutdown -h now 是关闭运行的程序后,刷新缓冲区后再调用init 0关机
sudo init 0 #这个是直接关机,不管系统内运行的程序
5,查看磁盘状态
df -h #以人比较好看懂的单位返回各个磁盘或者分区的状态
6,nmap扫描局域网ip
nmap是个很强大的工具,
sudo apt-get install nmap sudo nmap -sP 192.168.3.0/24 #快速检测192.168.10.0/24网段中有哪些存活主机
扫描局域网内某一段ip地址的信息
nmap 192.168.0.101-110 #扫描局域网内部0.101到0.110的IP、地址,系统会列出端口等很多详细信息
扫描局域网内的ip和mac地址:
sudo nmap -sP -PI -PT 192.168.1.0/24
详情可以参考:实例走起
7,ubuntu系统目前运行的进程相关查询
常规查询:
ps -aux #显示当前系统的所有进程 ps -aux|grep 'xxx' #查找和xxx相关的进程的信息,xxx有可能是名字,pid等等
按照进程号查找相关信息:
ps -q 1234 -o command #-q表示快速查找,-o表示你需要啥东西,你需要user写user,总之是ps能查到的都可以写 #我的ps可以查到这些:USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
8,向mysql数据库导入或者导出数据
create database 数据库名称; mysql -h localhost -u root -p yourdatabase < ./hehe.sql #这是从sql文件中,向数据库yourdatabase导入数据 mysqldump -h localhost -u root -p yourdatabase > ./test.sql #从yourdatabase中导出数据并且保存为test.sql
9.查看磁盘相关命令
df -h #用比较可视化的方式查看系统整个磁盘的信息 du -sh ~/home #查看文件或者文件夹的大小,有的文件需要sudo权限
10,grep命令查找匹配的字符上下几行
grep -C 3 love filename 显示filename文件中,love行上下3行内容(含love行) grep -A 3 love filename 显示filename文件中,love行下3行内容(含love行) grep -B 3 love filename 显示filename文件中,love行上3行内容(含love行) ##-B before ##-A after ##-C before+after
使用:
假设使用nmap查找局域网内某个设备的ip, nmap 192.168.0.10-100>ip.txt #把局域网内的0网段的10到100号ip都写出到ip.txt中 cat ip.txt|grep -B 7 xxx #从ip.txt中查找带‘xxx’字符的行,并且把本行和本行的前7行都打出来。比如我知道我的设备22端口开放,就可以尝试grep -B 7 22
11,watch持续调用某个命令,并且n秒刷新一次
watch -n 2 'cat /sys/devices/xxxx/temp' #每隔两秒查看一下系统某个文件的状态
灰常好用!
12,为ubuntu更新系统时间或者更换时区
date -R
#查看当前时间
tzselect
#系统会提示你选择你所在的洲,国,根据实际情况选择完成以后确认即可,不需要图形界面
然后复制一下系统文件就可以了:
sudo mv /etc/localtime /etc/localtime_old sudo cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
其他的设置目前还不没尝试,可参考原文档
因为原本的localtime是个软连接,而新的localtime是个文件,所以个人觉得,直接修改localtime的指向比较好,所以最终是这样的
sudo rm localtime sudo mv localtime_old localtime sudo ln -snf /usr/share/zoneinfo/Asia/Shanghai localtime #先把我刚刚copy过来的localtime删掉,然后把原本的localtime(现在叫localtime_old)的名字改回来,最后把软连接链接到上海所在的时区
有些时候,如果ubuntu处于没有网络的状态下,上述设置有可能不大管用(个人没测),此时就可以尝试手动修改时间啦!
命令如下:
sudo date -s MM/DD/YY //修改日期 sudo hwclock --systohc //修改生效 sudo date -s hh:mm:ss //修改时间 sudo hwclock --systohc //修改生效
改是可以改,但是改了以后就有问题了,重启以后时间又错乱了!坑爹啊,,,那么我们来好好看看时间吧。
依照个人经验,系统上有三个时间:
utc:“世界标准时间”,这个时间一般我们不用,和北京时间差n小时,我们不搭理它。
cst:我理解,这个基本上就是localtime,就是使用shanghai作为时区的那个时间。属于系统时间
硬件时间:这个就比较杠了,一般电脑如果带电池,就像自带手表一样,关机,断网,断电以后仍然会保证时间的准确性,靠的就是这个硬件时间。
好的,那么,在没有互联网的情况下(ntp校时不管用了哦),我们应该如何设置时间呢?
sudo timedatectl set-ntp false #把ntp校时服务关掉,不然你的时间你改不动哦,这个命令就相当于你在图形界面的date&time设置中把‘set the time’ 改为‘manually’ #开启ntp服务就填写true sudo timedatectl set-local-rtc 1 #设置系统硬件的时间为本地时间,也就是那个cst,相对应的,如果最后的参数为0,则是使用utc时间。 sudo timedatectl set-time "yyyy-mm-dd hh:mm:ss" #输入手动设置的时间
有人说,还需要设置sudo hwclock --systohc,我尝试过,,反正是不管用。。
timedatectl
#系统内详细的日期时间信息,蛮好用的
date -R
date
#查看系统时间,简略版
13,修改软连接
创建
ln -s 文件名 创建软连接的名字 #ln -s daqing.txt mylink为daqing.txt下创建一个叫mylink的软连接
修改
ln -snf 文件名 要修改的软连接名 #ln -snf xiaoqing.txt mylink 修改mylink软连接的指向,指向xiaoqing.txt
删除
rm 链接名字 #后面千万不要加斜杠,‘/’,其实加了也没啥,但是还是老老实实别乱动比较好
14,打开或者关闭ubuntu图形界面
关闭用户图形界面
sudo systemctl set-default multi-user.target
sudo reboot
开启用户图形界面
sudo systemctl set-default graphical.target
sudo reboot
15,配置pkg-config文件
如果在ubuntu上编译和开发c++,pkg-config是个非常好用的命令,他能够帮你管理头文件和a文件,让你不必在g++命令后面加上一大堆的-I,-L等,而且使用如下命令可以查看开发环境的位置:
pkg-config --cflags libavformat #查看头文件在哪里 pkg-config --libs libavformat #查看库文件在哪里 pkg-config --list-all #查看pkg-config管理的所有的项目名称和简介
比如我刚刚编译的ffmpeg包,在lib/pkgconfig下有一堆pc文件,很明显这是写好了给用户用的,给ffmpeg的贴心点赞!通过把path添加到变量PKG_CONFIG_PATH中,我们就能随心所欲的使用ffmpeg了,添加方式:
vim ~/.bashrc
#在最后添加一行:
export PKG_CONFIG_PATH=/usr/local/ffmpeg/lib/pkgconfig:$PKG_CONFIG_PATH
16,查找带有某个文件内容的文件
sudo find /etc/apache2 -name '*.conf'|xargs grep 'access.log' #find是常用的,不多讲 #从find出来的文件中查找带有access.log的文件
17,ubuntu18.04禁止某个服务开机启动
以apache为例,网上说的如下命令,真的一点都不管用
sudo update-rc.d -f apache2 remove #这句话的意思是删除apache2的开机启动脚本,亲测无法禁止开机启动,反而会删除很多有关开机启动的服务链接 #已经删除了的可以这样恢复 sudo update-rc.d apache2 defaults
真正的禁止开机自启是这样的:
sudo update-rc.d apache2 disable #关闭某个service的开机自启 sudo update-rc.d apache2 enable #打开某个service的开机自启
查看当前电脑中有哪些service
sudo service --status-all
18,ubuntu18开发板固定ip以及修改dns(非通用ubuntu18.04)
修改ip:
sudo vim /etc/network/interfaces
内容改为:
source-directory /etc/network/interfaces.d #上面这一句是默认的,建议不要动 auto lo iface lo inet loopback #给lo网卡设置ip巡回,具体啥意思不清楚,貌似和127.0.0.1有关,我所见的ubuntu电脑默认都有lo网卡,但是不排除有的没有,建议用lo之前先看看ifconfig命令 auto eth0 iface eth0 inet static address 192.168.3.201 gateway 192.168.3.1 netmask 255.255.255.0 #以上命令是,给eth0(有的不叫eth0)网卡设置链接信息,固定ip地址(static),网址是xx,网关是xx,掩码是xx
修改dns:
临时修改,立马生效
sudo vim /etc/resolv.conf #nameserver修改为 114.114.114.114
永久修改,重启也管用的
sudo vim /etc/systemd/resolved.conf
改为:
##找到有dns的一行,取消注释,改为如下的样子 DNS=114.114.114.114 ##未修改以前的配置是如下的样子: # This file is part of systemd. # # systemd is free software; you can redistribute it and/or modify it # under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation; either version 2.1 of the License, or # (at your option) any later version. # # Entries in this file show the compile time defaults. # You can change settings by editing this file. # Defaults can be restored by simply deleting this file. # # See resolved.conf(5) for details [Resolve] #DNS= #FallbackDNS= #Domains= #LLMNR=no #MulticastDNS=no #DNSSEC=no #Cache=yes #DNSStubListener=yes
那么问题来了,为啥要改俩配置文件?它俩什么关系?
/etc/resolv.conf是被systemd-resolved
这个服务托管的,通过netstat -tnpl| grep systemd-resolved
查看到这个服务是监听在53号端口上。而这个服务的配置文件为/etc/systemd/resolved.conf。
如果我们要想让/etc/resolve.conf
文件里的配置生效,需要添加到systemd-resolved的这个配置文件里DNS
配置项(如上面的示例,已经完成修改),然后重启systemd-resolved服务即可。
18,有关syslog文件夹的注意事项
syslog是系统级别的日志模块,服务名称叫rsyslog,日志存放位置在/var/log中,
目前仅知道次模块配置比较复杂,用户可以在/etc/rsyslog.d文件夹下编辑此模块的配置文件。
建议不要乱删除此文件下的日志文件,最起码mysql和apache的log不要删除,会导致mysql和apache跑不起来
如果不小心执行了rm -rf /var/log/*,如何恢复?
apache2:在/var/log下重建一个文件夹apache2。
mysql:在/var/log下重建一个mysql文件夹,并且里面要有数据,数据从哪里得来?要么你之前备份过,要么从另一台电脑上拷贝过来,我的解决方案是,去另一台电脑上拷贝了一份过来。。另一台电脑和我用的电脑账户名和密码都一样,mysql配置也基本一样