Linux 内核是开源类 Unix 系统宏内核。仅仅一个内核并不是一套完整的操作系统。有一套基于 Linux 内核的完整操作系统叫作 Linux 操作系统。Kernel 是 Linux 系统的核心,主要负责硬件的支持。
Linux 内核提供了安全补丁, bugfix 和新特性。
Linux 内核在 GNU 通用公共许可证第 2 版之下发布。
Linux 的 Kernel 主要提供以下五个基本的功能 1:
修改启动内核版本需要谨慎,每一步在确认知道自己在做什么的情况下再操作。Linux 内核版本变更可能导致网络访问异常,声音异常,甚至是桌面环境无法启动。在安装和移除内核时,确保已经已经阅读过相关帮助,确保自己知道如何选择不同版本的内核,如何恢复之前的版本,以及如何检查 DKMS 状态。
Linux 内核版本号由 3 组数字组成:第一个组数字。第二组数字。第三组数字
在 Linux 机器上执行如下命令查看当前正在使用的内核版本
uname -r
使用如下命令查看当前系统安装的内核版本
dpkg -l | grep linux-image
如果使用的是 Linux Mint 那么在 Update Manager 中,选择 View -> Linux Kernels 可以查看当前安装的版本和正在使用的版本,或者选择安装新的版本切换。
sudo apt search linux-image
sudo apt install xxx
sudo apt-get purge xxx
一个系统可以同时安装多个内核,但是运行时只能选择一个,当启动电脑时,在显示 GRUB 菜单时可以选择加载哪一个内核。(当只有一个系统安装时,GRUB 菜单可能被跳过,强制显示 GRUB 菜单可以在启动电脑时一直按住 Shift 按键)
在 Advanced options
选项中,可以选择系统上安装的内核版本,在启动时选择一个即可。
DKMS 全称是 Dynamic Kernel Module Support,它可以帮我们维护内核外的这些驱动程序,在内核版本变动之后可以自动重新生成新的模块。
sudo apt-get install dkms
内核包含了所有的开源驱动,一般都可以正常工作,私有的驱动(DVIDIA,AMD,Broadcom… 等等)不包含在其中。这些私有驱动(proprietary drivers)需要在安装时手动编译到每一个内核中。这个操作可以用 dkms 来完成。如果私有驱动无法正常编译到内核中,可能导致启动异常,所以需要提前检查
dkms status
《UNIX AND LINUX SYSTEM ADMINISTRATION HANDBOOK》第十一章 ↩
从 Android 开发官网下载 Android SDK,从事过 Android 开发的应该知道 adb 和 fastboot 工具,在完整 SDK 中这两个工具在 platform-tools 文件夹下。如果想要方便的使用这两个工具,可以将文件路径加入到系统环境变量中,这样以后就可以在任何目录使用 adb 和 fastboot 命令。
救砖,或者在 recovery 下没有备份又无法开机的情况下只能刷回原厂镜像救砖机。因此折腾需谨慎,刷机前请一定使用 recovery 备份系统及数据。可以从 Google 官网下载镜像。
https://developers.google.com/android/nexus/images#shamu
解压之后应该会有如下文件
bootloader-shamu-moto-apq8084-71.15.img 2016/01/06 07:19 10,636,288
flash-all.bat 2016/01/06 07:19 985
flash-all.sh 2016/01/06 07:19 856
flash-base.sh 2016/01/06 07:19 814
image-shamu-mmb29q.zip 2016/01/06 07:19 1,009,825,337
radio-shamu-d4.01-9625-05.32+fsg-9625-02.109.img 2016/01/06 07:19 118,272,512
解锁 bootloader 会抹去手机一切内容,需谨慎,总之只需要一句命令
fastboot oem unlock
然后利用音量键及电源键来确认解锁 bootloader, 之后运行
fastboot reboot
重启手机。
root 工具及教程来自 @Chainfire ,在此由衷的感谢他。
第三方的 Recovery 有以下的功能:
刷入 recovery
执行以下命令
fastboot flash recovery recovery.imgrecovery.img 即下载的 Recovery 镜像。
安装完 recovery 之后就能够快速的备份系统,恢复出厂设置,恢复备份数据,刷入新ROM,刷入ZIP
一张图解释什么是 kernel
Nexus 6 第三方的 kernel 有很多选择 比如 franco.kernel,这里推荐 ElementalX,有如下功能
安装 ElementalX kernel
6.0.1 (MMB29Q) 有效
下载文件,教程中需要用的软件及文件 https://yunpan.cn/cxCaHyqkKPwg9 提取码 db02
还有这里
具体步骤参考nexus6破解电信教程
简单来说破解4G步骤:
破解完成后请在手机拨号面板那输入 *#*#4636#*#*
看下首选网络是不是LTE/GSM/CDMA auto(prl)
部分内容为 《Linux 命令速查手册》读书记录。
uname -a # 查看内核 / 操作系统 /CPU 信息
head -n 1 /etc/issue # 查看操作系统版本
cat /proc/cpuinfo # 查看 CPU 信息
hostname # 查看计算机名
lspci -tv # 列出所有 PCI 设备
lsusb -tv # 列出所有 USB 设备
lsmod # 列出加载的内核模块
env # 查看环境变量
监视系统资源,包括跟踪正在运行的程序 (ps,top)终止进程(kill),列出打开的文件(lsof),报告系统内存占用(free),磁盘空间占用(df,du)等等。
ps aux # 查看系统正在运行的进程
ps -ef # 查看所有进程
ps f # 查看进程树
top # 实时显示进程状态
kill -9 PID # 终止正在运行的进程 -9 强制中断, -15 正常中止
lsof # 列出打开的文件
free -m # 查看内存使用量和交换区使用量
df -h # 查看各分区使用情况
du -sh 《目录名》 # 查看指定目录的大小
grep MemTotal /proc/meminfo # 查看内存总量
grep MemFree /proc/meminfo # 查看空闲内存量
uptime # 查看系统运行时间、用户数、负载
cat /proc/loadavg # 查看系统负载
mount | column -t # 查看挂接的分区状态
fdisk -l # 查看所有分区
swapon -s # 查看所有交换分区
hdparm -i /dev/hda # 查看磁盘参数(仅适用于 IDE 设备)
dmesg | grep IDE # 查看启动时 IDE 设备检测状况
这里列举了常用和网络相关的命令,包括查看本地 IP(ifconfig),判断网络连通性(ping,traceroute) 等等。其中 ifconfig, iwconfig ,route 等等命令都有双重用途,不仅能够查看网络连接属性,也能够进行配置。
ifconfig # 查看所有网络接口的属性
ifup eth0 # 开启网络
ifdown eth0 # 关闭 eth0 网卡
iwconfig # 查看无线接口属性
iptables -L # 查看防火墙设置
ping # 网络连通性
route -n # 查看路由表
netstat -lntp # 查看所有监听端口
netstat -antp # 查看所有已经建立的连接
netstat -s # 查看网络统计信息
traceroute https://google.com # 显示数据包从计算机路由到指定的主机经过的每一步
mtr # traceroute 更好的代替
host # 查看网站 DNS 结果
dhclient -r eth0 # 使用 DHCP 获得新网络地址
mtr 使用介绍
w # 查看活动用户
id 《用户名》 # 查看指定用户信息
last # 查看用户登录日志
cut -d: -f1 /etc/passwd # 查看系统所有用户
cut -d: -f1 /etc/group # 查看系统所有组
crontab -l # 查看当前用户的计划任务
chkconfig --list # 列出所有系统服务
chkconfig --list | grep on # 列出所有启动的系统服务
wc 命令是 Linux 下 Word Count 的缩写,用来统计文件中的字节数,字数,行数等等。
非常简单
wc [options] files
-c, --bytes 统计字节数
-l, --lines 统计行数
-m, --chars 统计字符数,不能和 -c 一起使用
-w 统计字数,一个字定义为由空白、空格或者换行分割的字串
-L, --max-line-length 最长行的长度
命令:wc file.txt
比如有如下文件:
cat file.txt
Linux
Debian
Ubuntu
Linux Mint
命令有如下结果
wc file.txt
4 5 31 file.txt
wc -l file.txt
4 file.txt
wc -c file.txt
31 file.txt
wc -w file.txt
5 file.txt
wc -m file.txt
31 file.txt
wc -L file.txt
10 file.txt
直接使用命令 wc file.txt
输出的内容对应
wc file.txt
4 5 31 file.txt
行数 单词数 字节数 文件名
使用管道命令或者重定向来避免命令打印文件名
wc 命令如果从管道命令或者重定向命令中接受输入,则不产生文件名输出,参考如下例子:
当 wc 接受文件名作为参数时,打印出文件名
wc -l /etc/passwd
41 /etc/passwd
当文件以管道形式或者标准输入时不打印文件名
cat /etc/passwd | wc -l
41
unusual redirection, but wc still ignores the filename
< /etc/passwd wc -l
41
typical redirection, taking standard input from a file
wc -l < /etc/passwd
41
由此可以看到,当文件被当成 wc 的参数传递过去的时候会打印出文件名,而其他标准输入时候不会打印出文件名。某些情况下,你可能希望打印文件名,因此有必要知道何时会打印文件名,而何时不会打印。
MultiTail是一个开源的ncurses的实用工具,可用于在一个窗口或单一外壳,显示实时一样的尾巴命令,该命令拆分控制台为更多子窗口的日志文件的最后几行(很像显示多个日志文件到标准输出屏幕命令 )。 它还支持颜色突出显示,过滤,添加和删除窗口等。
他和tail的区别就是他会在控制台中打开多个窗口,这样可以同时监控多个日志。
apt install multitail
如果要在 CentOS,基于 Red Hat 的发行版中使用,需要开启 EPEL repository,然后安装
yum install -y multitail
监控两个日志文件,窗口上下
multitail /var/log/syslog /var/log/auth.log
如果要让窗口左右排布
multitail -s 2 /var/log/syslog /var/log/auth.log
同理,-s num
来表示后接多少个文件
进入 multitail 之后,有一些交互式命令
h
来打开帮助b
来选择打开的文件,使用上下键选择文件,一旦选择文件 multitail 会显示文件最后 100 行,使用 jk 移动光标,或者 gg/G 来快速移动到文件顶部或者最后,q 退出a
用来添加另外的监控日志文件Cache
在实际场景中有着非常广泛的使用,通常情况下如果遇到需要大量时间计算或者获取值的场景,就应当将值保存到缓存中。Cache
和 ConcurrentMap
类似,但又不尽相同。最大的不同是 ConcurrentMap
会永久的存储所有的元素值直到他们被显示的移除,但是 Cache
会为了保持内存使用合理,而配置自动将一些值移除。
通常情况下,Guava caching 适用于以下场景:
先来看一下 Guava 中 Cache 接口的定义:
com.google.common.cache.Cache
com.google.common.cache.Cache#asMap
com.google.common.cache.Cache#cleanUp
com.google.common.cache.Cache#get
com.google.common.cache.Cache#getAllPresent
com.google.common.cache.Cache#getIfPresent
com.google.common.cache.Cache#invalidate
com.google.common.cache.Cache#invalidateAll()
com.google.common.cache.Cache#invalidateAll(java.lang.Iterable<?>)
com.google.common.cache.Cache#put
com.google.common.cache.Cache#putAll
com.google.common.cache.Cache#size
com.google.common.cache.Cache#stats
Cache 接口定义的方法大都一目了然,值得一说的就是 stats()
方法,这个方法会返回一个 CacheStats
对象,这个对象包括了该 Cache 的一些统计信息,包括 hitCount
, missCount
,loadSuccessCount
,loadExceptionCount
,totalLoadTime
和 evictionCount
。
Cache
通过 CacheBuilder
类的 Builder 模式获取:
LoadingCache<Key, Graph> graphs = CacheBuilder.newBuilder()
.maximumSize(1000)
.expireAfterWrite(10, TimeUnit.MINUTES)
.removalListener(MY_LISTENER)
.build(
new CacheLoader<Key, Graph>() {
public Graph load(Key key) throws AnyException {
return createExpensiveGraph(key);
}
});
如果使用的场景中对应着 key 的值有默认的值,那么可以选择使用 CacheLoader
,如果没有默认值,那么仍然可以原子的 get-if-absent-compute
方法,在 get
方法中提供一个 Callable
,或者元素也可以通过 Cache.put
来直接插入到缓存中。
LoadingCache
是一个附加着 CacheLoader
的 Cache。LoadingCache<K,V>
在 Guava 中是一个 interface,通常是用来本地 Cache 缓存 k-v 数据,value 会一直保存在内存中直到被移除或者失效。实现这个接口的类期望是线程安全的,能够安全的在多线程程序中被访问。
当第一次调用 get()
方法时,如果 value 不存在则会触发 load()
方法,load 方法不能返回 null,否则会报错。
LoadingCache 是不支持缓存 null 值的,如果 load 回调方法返回 null,则在 get 的时候会抛出异常。
如果在 CacheLoader 中抛出异常,那么 Cache 会认为没有完成,所以新的值不会被 Cache。基于这一条规则,那么如何避免在 CacheLoader 中因为缓存 null 而抛出异常,那就是编程者自己处理 null 异常。
最正统的查询 LoadingCache
的方法是调用 get(k)
方法,这个方法如果查询到已经缓存的值会立即返回,否则使用缓存的 CacheLoader
自动加载一个新值到缓存并返回。因为 CacheLoader
可能会抛出异常,那么如果有异常,则LoadingCache.get(k)
会抛出 ExecutionException
异常。而如果 CacheLoader 抛出 unchecked 未检查的异常,则 get(k)
方法会抛出 UncheckedExecutionException
异常。
此时可以选择使用 getUnchecked(k)
方法,这个方法会将所有的异常包装在 UncheckedExecutionException 异常中。需要注意的是,如果 CacheLoader 声明了检查异常,也就是 CacheLoader 显式的定义了异常,就不能调用 getUnchecked(k)
方法
CacheBuilder 在构建 Cache 时提供了两种定时回收的方法
调用 LoadingCache 的 invalidate
方法可以使得 key 失效
Let’s Encrypt 是一个免费 SSL 证书发行项目,自动化发行证书,证书有 90 天的有效期。于是有了另外一个项目可以自动安装,自动续期。
直接上网站
选择 WEB 服务器版本,系统版本,然后执行脚本即可。
执行完成之后执行 certbot run
跟着步骤就行了。
在 crontab -e
编辑文件
0 0 1 * * /usr/bin/certbot renew --force-renewal
定时每天检查,如果要过期则自动延期。
tail 命令从指定点开始将文件写到标准输出。使用 tail 命令的 -f 选项可以方便的查阅正在改变的日志文件,tail -f filename 会把 filename 里最尾部的内容显示在屏幕上,并且不但刷新,使你看到最新的文件内容。
默认情况下 tail 会打印文件最后 10 行。
tail [OPTION] file
用于显示指定文件末尾内容,不指定文件时,作为输入信息进行处理。常用查看日志文件。
命令参数:
-f 循环读取,只要文件有修改会立即显示
-q 不显示处理信息
-v 显示详细的处理信息
-c NUM 显示的字节数
-n NUM 显示行数
--pid=PID 与 -f 合用,表示在进程 ID,PID 死掉之后结束。
-q, --quiet, --silent 从不输出给出文件名的首部
-s, --sleep-interval=S 与 -f 合用,表示在每次反复的间隔休眠 S 秒
命令:
tail -n 5 /var/log/syslog
说明:
显示文件最后 5 行内容,使用重定向可以将最后 10000 行重定向到其他文件,比如
tail -n 10000 /var/log/syslog > newfile.log
命令:
tail -f /var/log/syslog
命令:
tail -n +5 /var/log/syslog
tailf 是 tail -f
的快捷版本,man 手册中 tailf 已经被启用,可以使用一个 alias 来继续使用 tailf。
Linux 启动项管理
Debian/Ubuntu/Linux Mint 系利用 update-rc.d 来管理 Linux 自启动服务。RedHat/Fedora/CentOS 下貌似有一个 chkconfig 来管理。
而我使用的 Linux Mint 自带的启动服务管理配置地址在 ~/.config/autostart
目录下。
Linux 中的服务通常利用 /etc/init.d/
目录下的脚本进行启动,停止或者重新加载等操作。一般情况下如果安装完服务之后,该服务会自动启动。比如安装完 apache2 之后, apache 服务会在下次启动时自动启动。如果不需要 apache2 随机启动,可以你禁用自启动,然后在需要的时候手动的启动 apache 服务
# /etc/init.d/apache2 start
先看一下启动脚本的内容
# ls -l /etc/rc?.d/*apache2
lrwxrwxrwx 1 root root 17 Feb 5 21:47 /etc/rc0.d/K09apache2 -> ../init.d/apache2
lrwxrwxrwx 1 root root 17 Feb 5 21:47 /etc/rc1.d/K09apache2 -> ../init.d/apache2
lrwxrwxrwx 1 root root 17 Feb 5 21:47 /etc/rc2.d/K09apache2 -> ../init.d/apache2
lrwxrwxrwx 1 root root 17 Feb 5 21:47 /etc/rc3.d/K09apache2 -> ../init.d/apache2
lrwxrwxrwx 1 root root 17 Feb 5 21:47 /etc/rc4.d/K09apache2 -> ../init.d/apache2
lrwxrwxrwx 1 root root 17 Feb 5 21:47 /etc/rc5.d/K09apache2 -> ../init.d/apache2
lrwxrwxrwx 1 root root 17 Feb 5 21:47 /etc/rc6.d/S09apache2 -> ../init.d/apache2
运行级别(run level) 从 0,1到6,在每一个链接前有K和S区别,K 表示 Kill 停止一个服务,而 S 表示 Start 启动一个服务。
不同的运行级别定义如下:
# 0 - 停机
# 1 - 单用户模式
# 2 - 多用户,没有 NFS
# 3 - 完全多用户模式(标准的运行级)
# 4 – 系统保留的
# 5 - X11 (x window)
# 6 - 重新启动
Debian 系Linux下利用 rcconf 管理自启动脚本,rcconf的全称是 Debian Runlevel Configuration tool, 运行级别配置工具。作用和 update-rc.d 类似,但是更加直观简洁。他是一个 TUI(Text User Interface)。
sudo apt-get install rcconf
sudo rcconf
运行之后就会出现非常直观的配置界面,用方向键,空格,Tab就能够实现配置。如果熟悉命令依然可以通过 rcconf 命令来进行快速配置。
如果想要完全禁止 apache2 服务,需要删除 /etc/rcX.d/
目录下所有的链接,而使用 update-rc.d
# update-rc.d -f apache2 remove
添加自启动服务
# update-rc.d apache2 defaults
Adding system startup for /etc/init.d/apache2 ...
/etc/rc0.d/K20apache2 -> ../init.d/apache2
/etc/rc1.d/K20apache2 -> ../init.d/apache2
/etc/rc6.d/K20apache2 -> ../init.d/apache2
/etc/rc2.d/S20apache2 -> ../init.d/apache2
/etc/rc3.d/S20apache2 -> ../init.d/apache2
/etc/rc4.d/S20apache2 -> ../init.d/apache2
/etc/rc5.d/S20apache2 -> ../init.d/apache2
从上面的log中可以看到,默认的优先级是20(K和S后面数字)和 91 有很大区别。 S20 链接早于 S91 启动, K91 在 K20 之前停止。
如果想要 apache2 服务以 91 优先级启动或者停止,可以使用
# update-rc.d apache2 defaults 91
Adding system startup for /etc/init.d/apache2 ...
/etc/rc0.d/K91apache2 -> ../init.d/apache2
/etc/rc1.d/K91apache2 -> ../init.d/apache2
/etc/rc6.d/K91apache2 -> ../init.d/apache2
/etc/rc2.d/S91apache2 -> ../init.d/apache2
/etc/rc3.d/S91apache2 -> ../init.d/apache2
/etc/rc4.d/S91apache2 -> ../init.d/apache2
/etc/rc5.d/S91apache2 -> ../init.d/apache2
如果需要为启动和停止设置不同的优先级,则可以
# update-rc.d apache2 defaults 20 80
Adding system startup for /etc/init.d/apache2 ...
/etc/rc0.d/K80apache2 -> ../init.d/apache2
/etc/rc1.d/K80apache2 -> ../init.d/apache2
/etc/rc6.d/K80apache2 -> ../init.d/apache2
/etc/rc2.d/S20apache2 -> ../init.d/apache2
/etc/rc3.d/S20apache2 -> ../init.d/apache2
/etc/rc4.d/S20apache2 -> ../init.d/apache2
/etc/rc5.d/S20apache2 -> ../init.d/apache2
这样启动为20,停止为80. 而如果需要自定义不同的运行级别,则可以
# update-rc.d apache2 start 20 2 3 4 5 . stop 80 0 1 6 .
Adding system startup for /etc/init.d/apache2 ...
/etc/rc0.d/K80apache2 -> ../init.d/apache2
/etc/rc1.d/K80apache2 -> ../init.d/apache2
/etc/rc6.d/K80apache2 -> ../init.d/apache2
/etc/rc2.d/S20apache2 -> ../init.d/apache2
/etc/rc3.d/S20apache2 -> ../init.d/apache2
/etc/rc4.d/S20apache2 -> ../init.d/apache2
/etc/rc5.d/S20apache2 -> ../init.d/apache2
如此之后,在运行级别 2, 3, 4, 5 为S20 ,运行级别 0, 1, 6 则是 K80.
同样可以更加复杂
# update-rc.d apache2 start 20 2 3 4 . start 30 5 . stop 80 0 1 6 .
Adding system startup for /etc/init.d/apache2 ...
/etc/rc0.d/K80apache2 -> ../init.d/apache2
/etc/rc1.d/K80apache2 -> ../init.d/apache2
/etc/rc6.d/K80apache2 -> ../init.d/apache2
/etc/rc2.d/S20apache2 -> ../init.d/apache2
/etc/rc3.d/S20apache2 -> ../init.d/apache2
/etc/rc4.d/S20apache2 -> ../init.d/apache2
/etc/rc5.d/S30apache2 -> ../init.d/apache2
sudo chkconfig --add apache2
or
sudo chkconfig -- level 35 apache2 on
关于 chkconfig 更多的用法可以参考这里
在Linux下安装 Genymotion Android 模拟器。最近拾起 Android Development,Android 模拟器必不可少,用来用去 Genymotion 模拟器算是速度和效率最棒的模拟器了。
Genymotion 依赖 VirtualBox 运行,在安装之前确保已经安装 VirtualBox. 在Linux Mint下直接去 Software Manager 搜索 VirtualBox 然后点击安装即可。
Genymotion 安装需要一个 Genymotion 的个人账号,Genymotion 高级功能需要付费,所以去官网注册一个个人账号使用。 官网地址:https://www.genymotion.com
下载安装包,在注册账号登陆之后去首页按照自己的系统选择 32bit 或者 64bit 的安装包下载。目前最新的版本为 2.6.0.
假设安装包下载到 ~/Downloads
目录下,在终端:
# cd ~/Downloads/
# Move the downloaded file to ~/Android/ directory #
mv genymotion-2.6.0_x64.bin ~/Android/
# Set executable permission
chmod +x genymotion-2.6.0_x64.bin
# Install genymotion by running the file
./genymotion-2.6.0_x64.bin
# Navigate into genymotion directory
cd genymotion
# launch the genymotion #
./genymotion
运行 genymotion 之后,添加设备,此时需要登陆账号,有的时候会遇到 “unknown generic error” 错误,在我的观察下可能就是因为 genymotion 服务器挂了,等些时候再尝试即可。或者有的时候是因为代理的关系。
下载对应的镜像,然后就能够运行模拟器了。
为了方便使用可以将 Genymotion 的地址加入到 PATH 中,这样就能快速启动 Genymotion. 类似:
$ PATH=$PATH:/home/einverne/Android/genymotion/
在使用 Genymotion 的时候,有时会遇到 ”INSTALL_FAILED_NO_MATCHING_ABIS“ 错误。一些时候是因为 APP 和模拟器CPU架构的问题,但是在 Genymotion 这里需要额外安装一个文件。点击这里 去xda 下载 Genymotion-ARM-Translation_v1.1.zip 这个文件。并拖到模拟器中。这样就不会出现问题了。如果需要在模拟器中安装 GApps ,可以在上面的链接中找到对应的方法。
如果使用过程中出现 “An error occured while deploying the file. INSTALL_FAILED_CPU_ABI_INCOMPATIBLE” 这样的错误,利用上面的方法也能解决。造成这个错误的原因是因为 Genymotion 是一个基于 x86 的虚拟环境,不是一个 ARM 的模拟器。而 Genymotion 在更新过程中移除了 ARM Translation 和 Google Play Apps , 这样对开发者和使用者造成了一定的困扰,不过还好依然可以通过其他方法解决。