0%

1. rustup

1
2
3
rustup default nightly # use nightly version
rustup default stable # use stable version
rustup update # update rust version
Read more »

1. mac安装

1
2
3
4
./configure --prefix=$HOME/local
make
make check
make install
Read more »

1. 正则表达式的修饰符

1.1 /g

/g修饰符代表全局匹配, 查找所有匹配而非在找到第一个匹配后停止。
注意string.match和RegExp.exec的区别,前者的正则表达式不需要加上/g,而后者需要加上/g。

exec with a global regular expression is meant to be used in a loop, as it will still retrieve all matched subexpressions. So:

1
2
3
4
5
6
7
var re = /[^\/]+/g;
var match;

while (match = re.exec('/a/b/c/d')) {
// match is now the next match, in array form.
}
// No more matches.

String.match does this for you and discards the captured groups.

Read more »

1. 打开xcode时显示启动页

“Window” -> “Welcome to Xcode”
勾选”Show this window when Xcode launches”。

Read more »

1. tr

echo $PATH | tr ‘:’ ‘\n’

2. xargs

1
2
find . -type f | xargs -I{} md5sum {} # {} 是用来代替管道之前标准输出内容的。
cat ~/.zshrc | xargs -n 3

加 -I 参数 需要事先指定替换字符
args:xargs的默认命令是echo,空格是默认定界符。 默认替换符号是{}
-I {}批定了替换字符串,表示文件内容,能循环按要求替换相应的参数 使用-I指定一个替换字符串{},这个字符串在xargs扩展时会被替换掉,
当-I与xargs结合使用,每一个参数命令都会被执行一次:
-n num 后面加次数,表示命令在执行的时候一次用的argument的个数,默认是用所有的
-d 自定义定界符

3. IFS

IFS(internal field separator)界定符,默认有三种:空格、制表符、换行符。Bash默认只要找到其中一种,就分隔字符,如果要指定使用如下方式:

  • 指定只用换行: IFS=$(‘\n’)
  • 指定空格: IFS=’ ‘
  • 指定,: IFS=’,’,这个在处理csv文件中有帮助。

4. 重定向

Linux系统预留可三个文件描述符:0、1和2,他们的意义如下所示:
0——标准输入(stdin)
1——标准输出(stdout)
2——标准错误(stderr)

2>/dev/null
意思就是把错误输出到“黑洞”

/dev/null 2>&1
默认情况是1,也就是等同于1>/dev/null 2>&1。意思就是把标准输出重定向到“黑洞”,还把错误输出2重定向到标准输出1,也就是标准输出和错误输出都进了“黑洞”

2>&1 >/dev/null
意思就是把错误输出2重定向到标准出书1,也就是屏幕,标准输出进了“黑洞”,也就是标准输出进了黑洞,错误输出打印到屏幕。

重定向的符号有两个:>或>>,两者的区别是:前者会先清空文件,然后再写入内容,后者会将重定向的内容追加到现有文件的尾部。

5. 后台运行

ctrl + z 挂起程序,可以用bg恢复放入后台,恢复完之后可以用fg把后台任务召回前台。jobs可以查看后台任务,前面的+号代表默认后台任务,-号代表下一个默认任务。
ctrl + c 中断程序,不能恢复了。

默认情况下,当你在终端会话shell中运行脚本时,交互式shell会挂起,直到脚本运行完。可以在命令名后加一个&符号来让脚本或命令以后台模式运行。当你在后台模式运行命令或脚本时,交互式shell会返回,允许你继续输入其他命令。任何通过这种方法运行的后台进程仍会绑定到该终端会话。如果退出了终端会话,后台进程也会退出。

可以用nohup命令阻止这种情况发生。该命令会拦截任何发给某个命令来停止其运行的信号 (比如当你退出终端会话时)。这样就可以让脚本继续在后台运行,即便是你已经退出了终端会话。 当你将进程置入后台时,仍然可以控制它的运行。jobs命令可以查看该shell会话启动的进程。

只要知道后台进程的作业号,就可以用kill命令向该进程发送Linux信号,或者用fg命令将该进程带回到该shell会话的前台。你可以用Ctrl+Z组合键挂起正在运行的前台进程,然后用bg命令将 其置入后台模式。

1. ShadowSocks

ShadowSocks是Socks5代理。之前我在Bandwagon上有个OpenVZ的ShadowSocks代理,后来到期了,买了一个KVM的虚拟机,手工装了ShadowSocks.
网上有一键安装ShadowSocks的脚本,但是不支持CentorOS,只支持Debian和Ubuntu。我想用BBR加速,自带的镜像只有CenterOS有BBR,所以就手动安装。难点是Python的版本问题,CenterOS的默认自带Python时2.6版本,而ShadowSocks是要2.7版本。而如果升级了python,yum就使用不了,方案就是升级python,软连接python,然后yum还是使用python2.6,这样就不冲突。

1.1 CenterOS升级python为2.7

https://www.cnblogs.com/haoorhuai/p/9773628.html

安装python使用的是源码编译

1
2
3
4
5
6
7
8
9
10
11
yum -y update
yum groupinstall 'Development Tools'
yum install -y zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel expat-devel

wget https://www.python.org/ftp/python/2.7.15/Python-2.7.15.tgz
tar -zxvf Python-2.7.15.tgz
cd Python-2.7.15
./configure --prefix=/usr/local
make all
make altinstall
make clean

不用使用easy_install安装python,使用官方自己带脚本。

1
2
curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py
python get-pip.py --user

安装结束后使用pip2命令,不要使用pip。

1
pip2 install shadowsocks

1.2 安装ShadowSocks

https://www.linuxidc.com/Linux/2015-05/117290.htm

1
2
3
pip2 install shadowsocks
touch /etc/shadowsocks.json
vi /etc/shadowsocks.json

{
“server”:”138.128.208.158”,
“server_port”:443,
“local_address”: “127.0.0.1”,
“local_port”:1080,
“password”:”MyPass”,
“timeout”:600,
“method”:”rc4-md5”
}
备注:加密方式官方默认使用aes-256-cfb,推荐使用rc4-md5,因为 RC4比AES速度快好几倍。
各字段说明:

server:服务器IP
server_port:服务器端口
local_port:本地端端口
password:用来加密的密码
timeout:超时时间(秒)
method:加密方法,可选择 “bf-cfb”, “aes-256-cfb”, “des-cfb”, “rc4″等

使用配置文件在后台运行shadowsocks服务
[root@localhost /]# ssserver -c /etc/shadowsocks.json -d start
备注:若无配置文件,在后台可以使用一下命令运行:
[root@localhost /]# ssserver -p 443 -k MyPass -m rc4-md5 -d start
停止服务
[root@localhost /]# ssserver -c /etc/shadowsocks.json -d stop

2. BBR

Google的TCP BBR拥塞控制算法解析,只能内核4.9以上支持。

1
2
#   查看内核版本,含有 4.9 就表示 OK 了
uname -r

https://www.cnblogs.com/Eason1024/p/8177665.html
https://blog.csdn.net/dog250/article/details/52830576

3. 一键shadowsocks脚本

只支持debian和ubuntu
https://www.tennfy.com/2136.html

4. 拷贝公钥给目标服务器

[root@localhost .ssh]# ssh-copy-id -i id_dsa.pub omd@192.168.25.110 【 使用ssh登录的默认端口22】
[root@localhost .ssh]# ssh-copy-id -i id_dsa.pub –p 666 omd@192.168.25.120 【使用ssh登录设置的端口666】
https://www.cnblogs.com/ftl1012/p/ssh.html

1.快捷键

1.1 打开关闭side tool window

Ctrl + Cmd + F12

1.2 toggle terminal

Alt + F12

Read more »