分享一些最近的PPT吧
好久不写博客都长草了,贴一点最新的PPT。
好久不写博客都长草了,贴一点最新的PPT。
有同学问为什么我好久没写MySQL文章了,其实不是没写,是都写到咱们阿里云RDS MySQL数据库内核月报了,下面是地址。
Somebody asks me: why are you not writing mysql posts so long? In fact, it’s not my lazy, because of I post my research on <Aliyun RDS MySQL Database Kernel Monthly>. Following are URLs:
比较旧的归档在这里:
Older archives here:
http://mysql.taobao.org/index.php?title=%E8%B5%84%E6%96%99%E5%85%B1%E4%BA%AB#MySQL_.E5.86.85.E6.A0.B8.E6.9C.88.E6.8A.A5
新的月报都在这里可以看到:
And new posts here:
http://mysql.taobao.org/monthly/
我有空也会挑选一些很有价值的翻译成英文,给外国朋友们看。
If I’m free, I will choose some valuable articles from our <Aliyun RDS MySQL Database Kernel Monthly> to translate to English for foreign friends. :-)
最近1年开发从SVN/Bzr换到了Git,总得来说Git还是很好用的,这里总结了一些不错的命令。
git stash
我们有时会遇到这样的情况,正在分支a上开发一半,然后分支b上发现Bug,需要马上处理。
这时候分支a上的修改怎么办呢,git add 是不行的,有的git客户端版本会提示还有add过的文件没提交不能切换分支,有的git客户端版本会把修改带到b分支。
git stash 就是解决这个问题,它把当前工作区的修改和git add的内容都保存到一个地方,然后git reset HEAD,使工作区回到上一次提交,处于干净状态。然后就可以很放心的切到另外的分支b干活了。
git stash save “先给我保存一下,我要去别的分支修bug”
git stash list
git stash pop
git stash apply stash@{num}
git rebase
有的时候我们在一个分支a开发的时候,master已经进入了很多修改,这时候如果把a的修改提交上去,可能就会跟主干有冲突,需要在主干解决冲突才能提交,这样比较难看。
这时候git rebase就有用了,git rebase BRANCH_NAME可以把BRANCH_NAME分支的修改带到当前分支来,这样当前分支就有了BRANCH_NAME分支的所有内容,这样在当前分支开发的内容提交以后不会跟BRANCH_NAME有冲突,冲突在当前分支就可以解决。
git reset
可以取消已经提交的commit,一般我们只用git reset HEAD^。因为每个分支可能开发过程中为了保存过程以便回溯会有很多commit,但是我们要求进入主干时,每个功能和bugfix只能有一个提交,因此可以先用git reset退回到最早的commit,然后把自己的修改最后打包成一个commit,再去跟主干合并。
利用这两个命令,我们可以很好的管理我们的MySQL开发。我们只有一个master分支作为主干,不允许在主干上直接开发。每个同学根据feature和bug的issue建立分支,然后在分支上开发,不管开发过程中有多少个commit,我们要求最终提交每个bugfix或feature只能有一个提交。因此每个同学完成开发后,都需要git reset 退到最早的commit,git stash save宝存一下自己的修改,然后git checkout master; git pull拖一下最新的主干,然后返回自己的分支,再做git rebase master,把当前分支推进到主干,最后git stash pop弹出修改,有冲突则在当前分支解决,再git push。
最近连续做了两次任务,都是把Bzr的代码转移到Git中,这里记录一下操作步骤。
目标:把MariaDB 10.0.10的GA版本代码库导入公司的Gitlab中。
这里需要用到bzr的fastimport工具,可以从lp上获得最新的代码,放在bzr的plugin目录下。
➜ /Users/plx >cd ~/.bazaar/plugins
➜ /Users/plx/.bazaar/plugins >bzr branch lp:bzr-fastimport fastimport
然后执行bzr selftest fastimport会提示你python缺乏各种包,用easy_install安装即可。
特别注明的是,python-fastimport包必须安装0.92以下版本,否则跟bzr-fastimport不兼容,会缺少两个函数。
然后查看MariaDB 10.0.10版本对应的版本号,通过tag来查询:
➜ /Users/plx/Documents/Code/MariaDB/mariadb-10 >bzr tags | grep 10.0.10
mariadb-10.0.10 4140
这里可以看到10.0.10版本对应的tag号为4140,然后我们导出一份4140版本号的代码来操作。
bzr branch -r4140 lp:maria
完成之后就可以用bzr-fastimport工具了:
cd maria
git init
bzr fast-export --plain . | git fast-import
Gitlab上已经创建好一个m_10010的空项目,转换完成之后就可以上传到Gitlab了:
rm -rf bzr
rm -rf .bzr*
git remote add origin git@gitlab.alibaba-inc.com:m/m_10010.git
git push --mirror git@gitlab.alibaba-inc.com:m/m_10010.git
完成!