Author: jpuyy

  • git patch 的应用

    根据提交来创建 patch,并把创建的 patch 应用到其他 repo 上

    当要修补一个 bug 或开发新特性,新创建一个分支

    git checkout -b fix

    在做了一些提交之后,基于 master 输出一个 patch

    git format-patch master --stdout > fix.patch

    接下来把 patch 文件搞到其他 repo 中

    查看此 patch 有哪些改变

    git apply --stat fix.patch

    测试是不是可以应用 patch 上去

    git apply --check  fix.patch

    如果没有报错,可以进行下一步,应用 patch

    git am --signoff < fix.patch
  • 做一次 git 完美提交

    分离主题和内容
    主题控制在 50 个字符
    主题第一个字母大写
    主题行不要用句号结束
    主题行使用祈使语气
    内容每 72 个字符换行
    在内容里解释改变的大致内容 what 和原因 why (改变的方式 how 在 git diff 里可以看到,不用说)

    http://chris.beams.io/posts/git-commit/

  • ansible批量添加用户

    有用的 snippet

    ansible all  -l 'web' -m user -a "name=www shell=/bin/bash createhome=yes"
  • 局域网内一台机器用做网关

    虚拟机:192.168.1.111

    安装 pptp-setup

    yum install pptp-setup

    创建 pptp

    pptpsetup --create p1_jp1 --server p1.jp1.jpuyy.com --username user --password pass --start

    这之后会有文件 /etc/ppp/peers/p1_jp1

    # written by pptpsetup
    pty "pptp p1.jp1.jpuyy.com --nolaunchpppd"
    lock
    noauth
    nobsdcomp
    nodeflate
    name user
    remotename p1_jp1
    ipparam p1_jp1
    require-mppe
    

    对应的密码文件记录在 /etc/ppp/chap-secrets

    之后要想连接或断开 pptp,可以使用,做两个软链

    ln -s /usr/share/doc/ppp-2.4.5/scripts/pon /usr/local/bin/
    ln -s /usr/share/doc/ppp-2.4.5/scripts/poff /usr/local/bin/
    

    之后运行

    pon p1_jp1

    如果发现连不上,还需要启用 ip_gre 模块。参见这里

    打开 ip 转发

    更改 /etc/sysctl.conf

    net.ipv4.ip_forward = 1

    sysctl -p 生效

    设置 nat

    -A POSTROUTING -o ppp0 -j MASQUERADE

    替换默认网关

    ip route replace default dev ppp0

    至此,局域网中的其他机器可以设置把 192.168.1.111 做为网关了。

  • git diff 高亮显示改变的单词

    平时 git diff 都是以行级别的

    如果以单词级别的可以这样

    git diff --color-words
    git diff --word-diff
  • git cherry pick 任意选 commit merge 过来

    在 git 里,每一个 commit 都带有一个 sha1 的标识,在任何分支,任何状态下,如果你知道这次提交的相关情况,可以将一次 commit merge 过来。

    git cherry-pick 2379df