关于版本选择,参考官网 https://wiki.ubuntu.com/Releases
安装全新系统需要更换国内镜像源以保证速度
$ sudo cp /etc/apt/sources.list /etc/apt/sources.list_backup
$ sudo gedit /etc/apt/sources.list
# 更换源
$ sudo apt-get update
阿里云源(ubuntu 14.04)
deb http://mirrors.aliyun.com/ubuntu/ trusty main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-security main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-updates main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-security main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-updates main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-backports main restricted universe multiverse
参考:http://wiki.ubuntu.org.cn/源列表
注意版本:
Precise(12.04)版本,将上述列表地址中的 vivid 替换为 precise 即可
Trusty(14.04)版本,将上述列表地址中的 vivid 替换为 trusty
更新源 出现 Hash 校验和不符的解决办法
$ sudo rm -rf /var/lib/apt/lists/partial/*
# 更换源(排除网络问题,建议用阿里云源,速度不错)
$ sudo apt-get update
查看系统版本
$ cat /proc/version
显示操作系统32还是64位
$ sudo uname --m
i686 32位
x86_64 64位
显示内核名字
$ sudo uname --s
Linux
显示内核版本
$ sudo uname --r
3.13.0-36-generic
显示网络主机名
$ sudo uname --n
ubuntu
主机名一般存放在 /etc/hostname; 但是 Fedora 发行版将主机名存放在 /etc/sysconfig/network
修改主机名称
$ vim /etc/hostname
保存,重启系统
需要同时修改 hosts
$ vim /etc/hosts
127.0.1.1 ubuntu
显示cpu
$ sudo uname --p
i686 32位
x86_64 64位
查看 cpu 逻辑核心数,型号
$ cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq -c
4 Intel(R) Core(TM) i7-3537U CPU @ 2.00GHz
查看物理 cpu 颗数
$ cat /proc/cpuinfo | grep physical | uniq -c
查看 cpu 运行模式
$ getconf LONG_BIT
64
如果显示32,说明当前 CPU 运行在32bit模式下, 但不代表 CPU 不支持64bit
查看 cpu 是否支持64bit
$ cat /proc/cpuinfo | grep flags | grep ' lm ' | wc -l
4
结果大于0, 说明支持64bit计算. lm指long mode, 支持lm则是64bit
查看 cpu 信息概要
$ lscpu
查看 cpu 详情
$ cat /proc/cpuinfo
查看内存信息
$ cat /proc/meminfo
格式化U盘(需卸载/取消挂载后才能格式化)
$ sudo fdisk -l
$ sudo mkfs.vfat -F 32 /dev/sdb1即可将u盘格式化为fat32格式
- 刻录镜像文件制作U盘启动盘
$ dd if=ubuntu-14.04.1-desktop-amd64.iso of=/dev/sdb
ubuntu 16.04 没有笔记本wifi
查看硬件设备
$ lspci -vnn | grep Network
03:00.0 Network controller [0280]: Realtek Semiconductor Co., Ltd. RTL8192EE PCIe Wireless Network Adapter [10ec:818b]
安装驱动
$ git clone [email protected]:lwfinger/rtlwifi_new.git
$ cd rtlwifi_new
$ make
$ sudo make install
关闭ubuntu桌面上的错误报告
$ sudo vim /etc/default/apport
enabled=1
修改为
enabled=0
ubuntu 连接 vpn 失败的解决办法
打开:网络链接,选择VPN标签,编辑选择的VPN,在VPN标签里,选择“高级”。
选中“使用点到点加密(MPPE)”
tree 显示目录树形结构
$ sudo apt-get install tree
$ tree ./
shell获取当前执行脚本的路径
file_path=$(cd "$(dirname "$0")"; pwd)
或者
file_path=$(cd `dirname $0`; pwd)
- 脚本文件的绝对路径存在了环境变量 file_path 中,可以用
echo $file_path
查看完整路径
在shell中:
$0: 获取当前脚本的名称
$#: 传递给脚本的参数个数
$$: shell脚本的进程号
$1, $2, $3...:脚本程序的参数
- ubuntu shell 终端中以窗口形式打开一个文件夹
$ nautilus
$ nautilus /tmp
- mac shell 下以窗口形式打开一个文件夹
$ open ~
可以用 alias 命令来给 nautilus 命令设置别名
$ alias opendir='nautilus'
但是这样操作只能在本次打开的shell终端中有用,下次启动shell终端命令失效, 可以将命令写入配置文件中
$ vim ~/.bashrc
打开配置文件后将 alias opendir='nautilus' 添加到配置文件中:
alias openpdf='xdg-open'
alias opendir='nautilus'
这样在下次启动 shell 时命令还能使用
linux 终端打开图片文件(图片需要完整路径才能打开)
$ eog example.png
eog 全称:eye of gnome,是 linux 下内置的图片查看器。
linux 终端打开 Google Chrome 浏览器
$ google-chrome
linux 终端通过代理打开 Google Chrome 浏览器
$ google-chrome --proxy-server="socks5://192.168.2.157"
ubuntu 解压 RAR
$ sudo apt-get install p7zip-rar
ubuntu 解压 windows 的 zip 文件出现乱码
$ sudo apt-get install unar
$ unar file.zip
统计当前目录下指定后缀名的文件总个数命令
$ find . -name "*.html" | wc -l
统计项目目录中代码行数
# 指定后缀
$ find . -type f -name "*.py" | xargs wc -l
# 指定后缀(方式二)
$ find . -name "*.py" | xargs wc -l
# 过滤某些后缀
$ find . -type f ! -name "*.pyc" | xargs wc -l
SSH 免密登陆远程主机
将本机公钥添加到对方 authorized_keys 中
$ ssh-copy-id user@host
or
$ ssh user@host 'mkdir -p .ssh && cat >> .ssh/authorized_keys' < ~/.ssh/id_rsa.pub
注意权限设置:
1) .ssh目录的权限必须是700
2) .ssh/authorized_keys文件权限必须是600
$ chmod 600 authorized_keys
查看系统所有 shell 版本
$ cat /etc/shells
# /etc/shells: valid login shells
/bin/sh
/bin/dash
/bin/bash
/bin/rbash
查看当前 shell 版本
$ echo $SHELL
/bin/bash
安装 zsh
$ sudo apt-get install zsh
安装 oh-my-zsh Oh My Zsh 只是一个对 zsh 命令行环境的配置包装框架,但它不提供命令行窗口,更不是一个独立的 APP。 Oh My Zsh 并不是某个命令行工具的替代品,而是和它们互为补充。
$ wget --no-check-certificate https://github.com/robbyrussell/oh-my-zsh/raw/master/tools/install.sh -O - | sh
替换bash为zsh:
$ chsh -s /bin/zsh
or
$ chsh -s $(which zsh)
查看 zsh 当前的版本号
zsh --version
将主题设置为随机
$ vim ~/.zshrc
ZSH_THEME="random"
命令输出当前主题的名称
$ echo $ZSH_THEME
pip 安装时默认访问 pypi 的,但是 pypi 的速度对于国内来说有点慢,还在国内也有一些 pip 的镜像源,造福广大程序员
pipy 国内镜像目前有:
http://pypi.douban.com/ 豆瓣
http://pypi.hustunique.com/ 华中理工大学
http://pypi.sdutlinux.org/ 山东理工大学
http://pypi.mirrors.ustc.edu.cn/ 中国科学技术大学
安装时我们可以手动指定 pip 源
$ pip -i http://pypi.douban.com/simple install Flask
或者修改 pip 源配置
$ mkdir ~/.pip
$ vim ~/.pip/pip.conf
[global]
index-url = http://mirrors.aliyun.com/pypi/simple/
[install]
trusted-host=mirrors.aliyun.com
或者
[global]
index-url = http://pypi.douban.com/simple
[install]
trusted-host=pypi.douban.com
由于最新的 pip 安装需要使用的 https 加密,所以在此需要添加 trusted-host
参考:http://mirrors.aliyun.com/help/pypi
pip 安装 gnureadline 报错: /usr/bin/ld: cannot find -lncurses
$ sudo apt-cache search ncurses- | grep ncurses
$ sudo apt-get install libncurses5-dev
添加 curl 代理 (curl/wget)
$ vim ~/.curlrc
添加
proxy = http://127.0.0.1:8087
帅气终端(亮点是快速分屏)
$ apt-get install terminator
首先设置等宽字体 mono 12号
然后可以设置背景图片 透明度
杀掉当前所有的MySQL连接
MariaDB [(none)]> select concat('KILL ',id,';') from information_schema.processlist where user='www' and db='test';
shadowsocks(python)
pip install shadowsocks
{
"server":"my_server_ip",
"server_port":8388,
"local_address": "127.0.0.1",
"local_port":1080,
"password":"mypassword",
"timeout":300,
"method":"aes-256-cfb",
"fast_open": false
}
To run in the foreground:
ssserver -c /etc/shadowsocks.json
To run in the background:
ssserver -c /etc/shadowsocks.json -d start
ssserver -c /etc/shadowsocks.json -d stop
桌面版系统也可以安装图形版 shadowsocks-qt5
sudo add-apt-repository ppa:hzwhuang/ss-qt5
sudo apt-get update
sudo apt-get install shadowsocks-qt5
查看网络出口IP
$ curl ifconfig.me
101.231.185.66
SysVinit to Systemd Cheatsheet/zh
https://fedoraproject.org/wiki/SysVinit_to_Systemd_Cheatsheet/zh
Sysvinit 命令 | Systemd 命令 | 备注 |
---|---|---|
service frobozz start | systemctl start frobozz.service | 用来启动一个服务 (并不会重启现有的) |
service frobozz stop | systemctl stop frobozz.service | 用来停止一个服务 (并不会重启现有的)。 |
service frobozz restart | systemctl restart frobozz.service | 用来停止并启动一个服务。 |
service frobozz reload | systemctl reload frobozz.service | 当支持时,重新装载配置文件而不中断等待操作。 |
service frobozz condrestart | systemctl condrestart frobozz.service | 如果服务正在运行那么重启它。 |
service frobozz status | systemctl status frobozz.service | 汇报服务是否正在运行。 |
ls /etc/rc.d/init.d/ | systemctl list-unit-files --type=service (推荐) ls /lib/systemd/system/.service /etc/systemd/system/.service | 用来列出可以启动或停止的服务列表。 |
chkconfig frobozz on | systemctl enable frobozz.service | 在下次启动时或满足其他触发条件时设置服务为启用 |
chkconfig frobozz off | systemctl disable frobozz.service | 在下次启动时或满足其他触发条件时设置服务为禁用 |
chkconfig frobozz | systemctl is-enabled frobozz.service | 用来检查一个服务在当前环境下被配置为启用还是禁用。 |
chkconfig --list | systemctl list-unit-files --type=service (推荐) ls /etc/systemd/system/*.wants/ | 输出在各个运行级别下服务的启用和禁用情况 |
chkconfig frobozz --list | ls /etc/systemd/system/*.wants/frobozz.service | 用来列出该服务在哪些运行级别下启用和禁用。 |
chkconfig frobozz --add | systemctl daemon-reload | 当您创建新服务文件或者变更设置时使用。 |
# 先查看内存使用情况
$ df -h
$ cd /boot
# 查看系统正在使用的image镜像是什么
$ uname -a
# 在boot 中删除无关镜像
$ eg: rm -rf initrd.img-4.4.0-62-generic initrd.img-4.4.0-98-generic vmlinuz-4.4.0-62-generic vmlinuz-4.4.0-98-generic