共计 4743 个字符,预计需要花费 12 分钟才能阅读完成。
Ubuntu16 升级到 18.04
“”“有特殊新颖强迫症癖好可以升下,如果你觉得 16.04 好用,就根本没必要升了”“”我当时租的 云服务器通常都是 16.04,现在估计也是 16.04 较多
我是个 Python3 的玩家,我只想用 Python 的最新版,或最新标准版 3.6-3.7
道理很简单,我追求新颖,虽然新版不稳定,但是你可以尝鲜并领先于别人。。。废话不多说:Ubuntu16.04: 默认装的是 Python2.7 + Python3.4 或 3.5
Ubuntu18.04: 默认装的是 Python2.7 + Python3.6.+
我喜欢升级系统版本来直接让对应软件升级:lsb_release -a # 查看系统版本
apt update # 一路选 Y
apt dist-upgrade
apt autoremove # 一路选 Y
apt install update-manager-core # 比较重要
do-release-upgrade -d # 完事
注:如果其中某个命令过程弹出一个黑窗口让你选择,我记得有个
core-new-update 字眼的,选这个即可 # 选择 新 核心
vim 多行注释(Python 为例)
Ubuntu 是肯定可以用,CentOS 我记得好像用不了
直接一套连招:注释:1. ctrl + v
2. 按 下 箭头方向键,选中多行
3. shift + i
4. 输入 #
5. 按两下 ESC 键
取消注释:1. ctrl + v
2. 按 下 箭头方向键,选中多行
3. 按 x 键
注:此套连招,需要熟练度,如果不行就多练练。手不好使,就不要怪我了~~~~
vimrc 简单配置:
“”“tab = 4 缩进,
设置行号
基于文件名的简单语法高亮
不要想着删一行,直接打开 vimrc 全部复制上去,保存退出就可以用了”“”vi ~/.vimrc
syntax on
set nu
set expandtab
set tabstop=4
set shiftwidth=4
set softtabstop=4
locate 查询库
locate xxx # 虽然很简单的命令,但是如果,一直为下线,并且还想查找新东西,那么需要更新库
updatedb # 更新搜索库,完事
如果 updatedb 命令出错,那就安装一下 mlocate 就好了:yum/apt-get install mlocate
htop 查看服务器负载
ubuntu/centos 中有
top:此命令可以详细查看服务器各种负载,资源状况,但是看着不方便,非常费劲
htop:top 的升级版,容易看出资源消耗情况
如果未安装,可通过
apt-get/yum install htop 安装
htop -d 0.1 # 0.1 秒动态更新一次资源数据。看起来有一点炫。
pkill
ps -el 查看 PId + kill -9 PID # 这套连招可强制杀死一个进程
但假如你有一连串的 python 进程 想要 全部 KILL
pkill python # 完事,和 python 有关的全 KILL 掉了,也可以通过通配符 * 的方式来简写
patree 列出进程
tree: 此命令用来列出目录层级结构
pstree: 用来列出 正在运行的 程序(所有进程的层级结构,进程名)pstree -p: 以层级的方式,不仅列出进程名,还列出所有进程的 (PID)
alias 改名
vi /etc/profile
alias python='python3' # 这里是举个例子,配完,python 命令就等价于 python3 命令
alias pip='pip3'
source /etc/profile # 不要忘记,这条命令 更新一下配置文件
重定向管道 (> 与 tee)
date > date.txt # 截流,屏幕上不显示
date | tee date.txt # 不截流,屏幕上显示,并且还能输入到文件
! 叹号命令
”“! 命令前缀 : 运行最后一条以这个前缀开头的命令”“假如下面是你最后按顺序再 command 终端 输入的四条命令:python aaa.py
python bbb.py
npm run dev
pip install ccc
需求:你想迅速运行 python bbb.py 这条命令
你只需
!py # 即可,愣着干啥呢,已经完事了,这条命令就等于你上面那一大串
解惑:1. !py -> py 开头的有两条,为啥不执行第一条 python aaa.py
因为 ! 叹号 的语法意思就是选择 最后出现以 py 开头的执行。2. 为啥直接 !p 不行呢?因为以 p 开头的最后一条命令是 pip install ccc。这也不是你想要的啊。
ctrl+z 和 & 和 nohup 和 screen
ctrl+c:强制终止(最常用的,先提出来。。。。应该都知道的。。)ctrl+z:可以把正在运行中的程序挂起到后台(注意这时候程序就暂停了)jobs: 粗略列出 后台挂起的程序
jobs -l: 详细列出 后台挂起的程序(其实就是多列出了个 PID)kill -9 PID # 顺水推舟地使用此命令来通过 PID 干掉后台挂起的程序
fg: 把挂起的后台的程序 拿回来继续执行
fg 程序编号: 如果有多个后台挂起的程序,选择一个继续执行,编号可通过 jobs 查看。使用场景:加入正在 vim 编辑东西,想跳出编辑器,写点别的,那么可以 进行下面操作:不要保存,直接 ctrl+z
然后去 做别的事
做完了想回到 vim 继续编辑剩下的内容, 直接 fg
&:运行 的 时刻 就直接 放到后台 (不实用)
eg: ( 通常是费时的操作,或者长时间占用 command 命令行)sleep 100 & # 这样费时 100 秒的操作,直接让它滚去后台执行,别占我地方
局限:假如你用 python xxxx.py & 运行一个 web 服务器,虽然它会滚去后台一直运行。前台 command 界面看起来很干净了。但是,如果有用户请求过来,你服务器收到打印在终端的信息 可不会乖乖打印在后台。打印信息会钻出来到前台 command 界面来恶心你。。。。。为了解决这一问题,请移步 下面 ...
nohup: (通常和 上面的 & 联合使用)(实用性一般)eg: 同样运行一个服务器
nohup python xxx.py &
# 它会乖乖的滚去后台执行,并且将要打印的消息 也不会打印到前台,也不会打印到后台。那打印的内容去哪了呢??nohup 会自动给你 把打印的东西重定向 到一个 nohup.out 文件,通常在当前目录下
# 这时你的前台 command 就不会受到 骚扰了。。。。也许你以为它很好用了,可以完美的决绝运行一个费时的进程。但是 它依然是个 loser。。.
局限:当我一直用 nohup.out 部署一些服务程序的时候,一部署就是很多天。当时学校断电(我租的阿里云 ECS 服务器). 虽然服务器可以不间断的执行。但是 我需要 用 xshell 一直去远程 查看我的 程序运行的怎么样了啊,是否崩了?可惜的是,每次 xshell 关闭了,你再上去,想找 通过 nohup & 连招 放到后台程序的时候,你会痛苦无比。。。非常惨
后来。。。。。。。。。screen:(会话机制)没错,后来我就发现了 这个 screen 工具
如果你那里没有,就安装一下喽:apt-get / yum install screen
然后需要配置一下:vi ~/.screenrc # 创建文件
shell -$SHELL # 输入此行内容,保存退出
至于为何配置这个:说实话我有点忘了
貌似不同 screen 会话对于不同的 shell 权限有限制,导致很多东西用不了,so do it
直接说一套我常用且超级实用连招把:eg:
screen -S 会话名 # 创建 并 进入这个会话(就像进入另一个世界,但资源共享)python xxx.py # 举例子,这是我的爬虫程序,需要运行 三天
ctrl + a + d # 跳出会话,回到正常命令行,但是这个会话以及你的程序依然在运行,....... 这段时间(除了关闭服务器)你做什么都行,关闭 shell 也可以的。screen -r 上面的会话名 # 恢复到会话中,你会发现,爬虫程序还在那里好好的运行呢。如果你忘记会话名了,不要紧:screen -ls # 这条命令会列出所有 你创建过的会话,你也可以看到会话名
总结:所以,我不知道阁下能不能感受到 screen 的魅力。我们可以 通过 screen -r 这一条命令来 迅速回到程序运行的环境。nohup &:你用这个执行的程序,关了 xshell, 你再连,你就不好找这个运行的程序了
screen 有一套完好的系统(就像有开关一样)来控制会话
你进入 screen 会话中写程序,screen 自然就能有条不紊的管理好 你程序的运行状态
举个白话例子:你正遛二哈呢,突然有急事:nohup & : 你说:‘二哈,等我回来,自己玩把’你回来时,二哈跑丢了。(不受控制,程序找不到了,虽然可以花力气找到)screen : 你说:‘二哈,等我回来,自己玩吧,但我要把你拴起来’你回来时,二哈还在那里乖乖的玩。(程序有效的受到控制,你可以轻松定位)
sudo su 等操作
不好意思,用了好几年 linux:什么 su- su 之类的,我至今都没搞太明白。。。。。。。。。。但是,我只用下面这一条命令,这些年就没遇到过问题:sudo -s # 变为 root, 如果你之前输入过密码,这条命令还会免去让你输入密码的环节
环境变量
把某路径加入到环境变量中:vi /etc/profile
export PATH=$PATH:/XXX/XX
做一些配置:vi /etc/profile
vi ~/.bashrc
等修改完后
source /etc/profile # 用一个 source 命令执行一下使配置更新生效
注:Linux-shell 我研究的不深, 所以这里可能有些说的不是特别明朗。其实 这些配置文件 以及 source . sh bash 这些命令 和 用户 以及权限等都是有很大关系的。有兴趣可自行深入了解
SSH 远程连接小坑
假如你的 xshell 连接不上远程服务器,可能未开启 或 未安装 sshd 服务
如下命令即可:sudo apt-get install openssh-client # 安装客户端配置
sudo apt-get install openssh-service # 安装服务器配置
systemctl start sshd.service # 开启服务
如果你的普通用户可以连接,但是你的 root 不能登录:vim /etc/sshd/ssh_config
PermitRootLogin yes # 找到这个改为 yes,保存退出就完事了
MySQL5.7+/MariaDB 修改密码小坑
当阁下还在停留在 Mysql5.7 版本之前,修改密码可以用下面这两种方式:mysqladmin -uroot password -p
或内部设置:update user set password=password('root') where user='root'
但是 MySQL5.7 之后 或者 MariaDB , 上面这俩方法 都不能 修改密码了。正确修改方式:先进入 MySQL 交互式:MySQL -uroot -p
update mysql.user set authentication_string=password("密码") where user="用户名"
update user set plugin="mysql_native_password";
flush privileges
最后重启服务,完事
另外,值得提醒的一点容易出现的问题:无论你连接的是什么数据库,如果你连不上
首先你应该想到的是,数据库配置文件:bind 0.0.0.0 # 每种数据库几乎都需要先改成这样,才能被外界访问
其次,你用的是云服务器的话
看看是否放通了 对应数据库的宽口
最后,是否开了防火墙:没记错的话,Centos 和 Ubuntu 防火墙不是同一种,真正需要关闭可自行百度
其他命令
"""一时间也记不起来还用过哪些了"""
wc : 统计字, 词,行(自己选参数)curl : 可以请求 url,并返回数据(相当于一个小小爬虫),也可以向某个接口发送请求
ssh-keygen:生成公私密钥
cd - : 跳回到上一次的路径
lsb_release -a : 查看 Linux 发行版信息
grep : 过滤字符
tar : 压缩 / 解压
netstat : 查端口
等
正文完