1.äºè®¡å课ç¨
2.关于linux学习路线的源译问题 请教前辈
3.mycat 高可用
äºè®¡å课ç¨
ã壹ã äºè®¡ç®éè¦å¦ä»ä¹è¯¾ç¨ææ¨èå
æ¨èä¸åéçäºè®¡ç®è¯¾ç¨ï¼å¦åéäºè®¡ç®æç¨åºæ¥çå¦åé½è¯´æ¾å·¥ä½å¾å®¹æã
ãè´°ã Linuxäºè®¡ç®è¯¾ç¨å¹è®é½æåªäºå 容
linuxäºè®¡ç®å¤å¹è®è¯¾ç¨
第1é¶æ®µå¶ é¶åºç¡å ¥é¨
第2é¶æ®µ Linuxç³»ç»ç®¡ç&shellç¼ç¨
第3é¶æ®µ ç¾ä¸çº§è®¿é®éé群å®æ
第4é¶æ®µ åä¸çº§è®¿é®éæ ¸å¿é群å®æ
第5é¶æ®µ ä¸åæ ¸å¿ææ¯çåºå±æ¯æï¼äºè®¡ç®é群
第6é¶æ®µ å°ç¡ è°·ä¸æ课ç¨ï¼å¤§æ°æ®è¿ç»´
第7é¶æ®µ Pythonèªå¨ååæ¯ä¸æ导
linuxäºè®¡ç®å¹è®è·¯çº¿
ãåã äºè®¡ç®çåºç¡è¯¾ç¨
äºè®¡ç®æ¯ä¸å¥ç³»ç»ç解å³æ¹æ¡ãéè¦ä»å®è§çºµåå»çï¼åå°å¾®è§å ·ä½çæ个äºè®¡ç®çå项æä¸æ¯ãå®å±å为åºç¡æ¶æå±ï¼IaaSï¼ï¼å¹³å°æ¶æå±ï¼PaaSï¼ï¼è½¯ä»¶æ¶æå±ï¼SaaSï¼ï¼æå¡æ¶æå±ï¼BPaaSï¼ãæ¯ä¸ªå±é¢ç建设å®æ½è¿ç¨åå¯ä»¥ç¬ç«åå¨ï¼å¹¶æ²¡æå ååªåï¼å建åªåçå å顺åºãå ¶ä¸IaaSæ¯å¿ ç»ä¹è·¯ã纵åææ¡ä½äºï¼å横åç»åå»çãæ¯å¦ï¼IaaSå为åå¨æ± ï¼è´è½½åè¡¡æ± ï¼èç¹è®¡ç®æ± ï¼å ¶ä¸ååç»å为å°åæºè®¡ç®æ± ï¼æå¡å¨è®¡ç®æ± çãåææä½ç³»ç»çæ¬çä¸ååç»åï¼çã
ãèã ç°å¨å¦ä¹ äºè®¡ç®è¯¾ç¨é½éè¦å¦ä»ä¹å 容ï¼ä»¥åæ¾ä»ä¹å·¥ä½å
ä½ å¥½ï¼äºè®¡ç®æ¯æªæ¥äºèç½çåå±è¶å¿ï¼ç°å¨å ¥è¡äºè®¡ç®è¡ä¸ï¼å°±æå³çæªæ¥çé«èªåå©ï¼ä¸ºæ¤å¾å¤äººä¼éæ©åå ä¸ä¸çå¦ä¹ å¿«éå ¥è¡ãäºè®¡ç®æ¶µççç¥è¯ç¹å¾å¤ï¼åºç¨é¢åä¹æ¯è¾å¹¿æ³ï¼æ¯ä¸ä¸ªé常好çéæ©ãåªè¦ææ¡çæ£çæè½ï¼äºè®¡ç®å°±ä¸èªç¶ä¸æé®é¢ã
å¦æä½ æ³è¦ä¸ä¸çå¦ä¹ äºè®¡ç®ï¼æ´å¤éè¦çæ¯ä»åºæ¶é´åç²¾åï¼ä¸è¬å¨2Wå·¦å³ï¼4-6个ææ¶é´ä¸çãåéç课ç¨å¾ä¸éï¼ä½ å¯ä»¥æ ¹æ®èªå·±çå®é éæ±å»å®å°çä¸ä¸ï¼å 好好è¯å¬ä¹åï¼åéæ©éåèªå·±çãåªè¦åªåå¦å°çä¸è¥¿ï¼åéèªç¶ä¸ä¼å·®ã
ãä¼ã äºè®¡ç®æ¶æå¸è¯¾ç¨è¦æä¹å¦ä¹
ï¼1ï¼Linuxä¹ç¾è¯¾æ¶
æ¬é¶æ®µè¯¾ç¨ä¼å¸¦é¢å¦åè¿å ¥Linuxçä¸çï¼æ·±å ¥å¦ä¹ 强大çLinuxæä½ç³»ç»ï¼å»ºç«æå¡å¨æä½æç»´ï¼å¹å »è¯å¥½çè¿ç»´ææ³ã
ï¼2ï¼å¼ºå¤§çLinuxæå¡å¨è¯¾æ¶
æ¬é¶æ®µè¯¾ç¨æ£å¼å¦ä¹ Linuxä¸åç§ç½ç»æå¡ï¼å½åäºèç½ä¸ç»å¤§å¤æ°çåºç¨åè½ï¼å¦ç½ç«ãè§é¢ã游æãè´ç©ãé®ä»¶ãä¸è½½çï¼é½éè¦ä¸åçLinuxæå¡æ¯æã
ï¼3ï¼ç©è½¬é群ä¸äºè®¡ç®ææ¯è¯¾æ¶
æ¬é¶æ®µè¯¾ç¨è®²æé群æ¶æãè´è½½åè¡¡ã代çæå¡ãåå¸å¼åå¨ã主ä»å¤ä»½ãäºè®¡ç®ãèæåãHadoopçåç§é«å¤§ä¸çç¥è¯ï¼å 容涵çäºäºè®¡ç®æ¶æå¸å·¥ä½ä¸æéçææææ¯
ï¼4ï¼ç½ç»å®å ¨ææ¯ä¸é¡¹ç®å®è·µè¯¾æ¶
æ¬é¶æ®µè¯¾ç¨æä½ ä¸ä¸çç½ç»å®å ¨ææ¯ï¼å®å ¨é²æ¤å·¥å ·ãé²ç«å¢ãå ¥ä¾µæ£æµçã
å¦ä¹ äºè®¡ç®ï¼è¿æ¯å å¼è¿å¥½
ãéã äºè®¡ç®ä¸»è¦å¦åªäºè¯¾ç¨
äºè®¡ç®æ¯åºäºäºèç½çç¸å ³æå¡çå¢å ã使ç¨å交ä»æ¨¡å¼ï¼é常æ¶åéè¿äºèç½æ¥æä¾å¨æææ©å±ä¸ç»å¸¸æ¯èæåçèµæºãäºæ¯ç½ç»ãäºèç½çä¸ç§æ¯å»è¯´æ³ãè¿å»å¨å¾ä¸å¾å¾ç¨äºæ¥è¡¨ç¤ºçµä¿¡ç½ï¼åæ¥ä¹ç¨æ¥è¡¨ç¤ºäºèç½ååºå±åºç¡è®¾æ½çæ½è±¡ãå æ¤ï¼äºè®¡ç®çè³å¯ä»¥è®©ä½ ä½éªæ¯ç§ä¸äº¿æ¬¡çè¿ç®è½åï¼æ¥æè¿ä¹å¼ºå¤§ç计ç®è½åå¯ä»¥æ¨¡ææ ¸çç¸ãé¢æµæ°ååååå¸åºåå±è¶å¿ãç¨æ·éè¿çµèãç¬è®°æ¬ãææºçæ¹å¼æ¥å ¥æ°æ®ä¸å¿ï¼æèªå·±çéæ±è¿è¡è¿ç®ã
ç®åæ们çäºè®¡ç®ç课ç¨ä¸ºç±æµ å ¥æ·±ã循åºæ¸è¿çå®æ´è¯¾ç¨ä½ç³»ï¼å æ¬ç»åLinuxçç½ç»åºç¡å®æãLinuxç³»ç»é ç½®åæå¡æ·±åº¦è§£æãShellèæ¬èªå¨åè¿ç»´é¡¹ç®å¼åãå¼æºæ°æ®åºMySQL DBAæ¶æåä¼åã主æµWeb æå¡å¨Nginxæ¶æä¼åã大åç½ç«é«å¹¶å项ç®LVSå®ææ¹æ¡ãé«å¯ç¨é群ææ¯ãåå¸å¼åå¨ææ¯Cephãå®å ¨é²å¾¡ææ¯ãæ§è½ä¼åæ¹æ¡ãPythonèªå¨åè¿ç»´å¼åææ¯ãç§æäºå¹³å°ææ¯KVM ãOpenstackã容å¨ææ¯Dockerçã
äºè®¡ç®å¦ä¹ 课ç¨å¤§çº²å¦ä¸ï¼
1. Linuxäºè®¡ç®ç½ç»ç®¡çå®æ
2. Linuxç³»ç»ç®¡çåæå¡é ç½®å®æ
3. Linux Shellèªå¨åè¿ç»´ç¼ç¨å®æ
4. å¼æºæ°æ®åºSQL/NOSQLè¿ç»´å®æ
5. 大åç½ç«é«å¹¶åæ¶æåèªå¨åè¿ç»´é¡¹ç®
6. ç½ç«å®å ¨æ¸éæµè¯åæ§è½è°ä¼é¡¹ç®å®æ
7. å ¬æäºè¿ç»´ææ¯é¡¹ç®å®æ
8. ä¼ä¸ç§æäºæ¶æåè¿ç»´å®æ
9. Pythonèªå¨åè¿ç»´å¼ååºç¡
. Pythonèªå¨åè¿ç»´å¼å项ç®å®æ
ãæã äºè®¡ç®éä¿è§£éï¼äºè®¡ç®éè¦å¦ä»ä¹è¯¾ç¨
äºè®¡ç®éä¿ç讲ï¼äºç«¯æ¶è®¾ä¸å°æ§è½å¼ºå²çæå¡å¨ï¼æ¯å¦ï¼æ ¸çCPU ãG çå åï¼N个T çåå¨çãå¨è¿æ ·æçé ç½®å¾å¯ä½çæå¡å¨ä¸éè¿èææºææ¯ï¼å建å å个èææºï¼ä»å®¿ä¸»æå¡å¨ç¡¬ä»¶é ç½®ä¸åååºèµæºé é¢ï¼ï¼å®¢æ·æºéè¿âè¿ç¨æ¡é¢åè®®âæâè¿ç¨æ§å¶åè®®âè¿æ¥å°èææºï¼è¿æ ·ä½ å°±å¯ä»¥å¨æ¬å°å®¢æ·æºä½¿ç¨è¿å°è¿ç¨çèææºã æ以çè¿ç®(计ç®)é½æ¯å¨è¿å°èææºä¸å®æçï¼æ¬å°å®¢æ·æºåªæ¯è¾å ¥ä¸è¾åºï¼éæ¬å°è®¡ç®ï¼ãå¦ä¹ äºè®¡ç®å¯ä»¥å»ççopenstack ,å¤äºè§£KVM çã
ãæã Linuxäºè®¡ç®è¯¾ç¨å ·ä½å¦ä»ä¹
ä¼å°±ä¸linuxäºè®¡ç®å¹è®å¦é¢çåäºå¹å »å¤æ¹ä½åå±çäºè®¡ç®äººæï¼è¯¾ç¨è®¾ç½®ç§å¦åçï¼é¢å0åºç¡äººåï¼æå¦å 容涵çåå广æ³ï¼å¤§å项ç®å®è®ï¼å®ææ§æ´å¼ºã
ä¼å°±ä¸Linuxäºè®¡ç®çå¹è®è¯¾ç¨å 容ä¸è¬å为å 个é¶æ®µï¼ç¬¬ä¸é¶æ®µä¸»è¦å¦ä¹ ç½ç»åºç¡ï¼å æ¬è®¡ç®æºç½ç»(以太ç½ãTCP/IPç½ç»æ¨¡å)ãäºè®¡ç®ç½ç»(ç½ç»QoSã交æ¢æºä¸è·¯ç±å¨)ï¼é å¤æä¼ä¸çº§é¡¹ç®å®æï¼IPå°åé ç½®ä¸DNS解æã
第äºé¶æ®µå°å¦ä¹ Linuxåºç¡ï¼å æ¬Linuxæä½ç³»ç»(æ件æéãä½ä¸æ§å¶ä¸è¿ç¨ç®¡ç)以åLinuxé«çº§ç®¡ç(SedãAwkå·¥å ·ãæºç ç¼è¯)ãä¼ä¸çº§é¡¹ç®å®æ为ï¼äºæ°æ®ä¸å¿ä¸»æºCPUèµæºå©ç¨çå®æ¶ç»è®¡ãåæç³»ç»ã
第ä¸é¶æ®µå¦ä¹ Linuxè¿ç»´èªå¨åï¼ä¼ä¸çº§é¡¹ç®å®æ为Python+Shellå®ç°ä¼ä¸çº§FTPæ件ç»ä¸ç®¡çã
第åé¶æ®µæ¯æ°æ®åºè¿ç»´ç®¡ççå¦ä¹ ï¼ä¼ä¸çº§é¡¹ç®å®æï¼MySQL Galeraé«å¯ç¨é群ç¯å¢é¨ç½²ãå¼æ¥æ¶æ¯éåé群RabbitMQé¨ç½²ä¸è¿ç»´ã
第äºé¶æ®µçå¹è®å 容为ä¼ä¸çº§äºæ¶æ管çä¸ç»¼åå®æ(PaaS+TaaS)ï¼é¡¹ç®è®ç»çæ¯åºäºLAMPæ¶æå®ç°äºè®¡ç®PaaSå¹³å°å ¸ååºç¨é¨ç½²ä¸è¿ç»´ï¼éè¿Nginxå®ç°åä¸çº§å¹¶å访é®å¤çã
æåä¸ä¸ªé¶æ®µå°±æ¯å°±ä¸æ导ï¼ä»ç®åãé¢è¯æå·§çå±é¢å©å¦åæåï¼å¹å »å¦åæ²é表达è½åï¼è®©å¦åæ¸ æ°äºè§£èä¸åå±è§åï¼æç¡®èªèº«å®ä½ï¼æ¾å°éåèªèº«åå±çå·¥ä½ã
ãçã 大æ°æ®äºè®¡ç®è¯¾ç¨è§é¢æç¨
ä¼ä¸ä¸é½ä½¿ç¨Linuxæ¥æ建é¨ç½²å¤§æ°æ®é¡¹ç®ãå¦ä¹ çæå ³ç³»åæ°æ®åºçMysql以åOracle,äºè§£å¤§æ°æ®çæºå¤´ï¼æ°æ®ä»æä½èæ¥ï¼å¦ä½éææ´å大æ°æ®,æè½æ´å¥½çäºè§£å¤§æ°æ®ãæ£ä¸å¹³å°å¤§æ°æ®å¼å课ç¨äºè§£hadoopçç¨éï¼å¿«éæ建hadoopå®éªç¯å¢ï¼ä¸ºä»¥åå¦ä¹ åæ建大æ°æ®é¡¹ç®æä¸åå®åºç¡ã
ãæ¾ã äºè®¡ç®ä¸å¤§æ°æ®ä¸ä¸ç主è¦è¯¾ç¨æ¯ä»ä¹
大æ°æ®çåºç¡ç¥è¯ï¼ç§æ®ç±»çï¼ä¸ªäººå»ä¹°æ¬ä¹¦å°±è¡äºï¼å¤§æ°æ®æ¶ä»£è¿æ ·ç书å¾å¤ä»ç»ç大æ°æ®çã
å¦å¤å¤§æ°æ®çææ¯ï¼å¦æ°æ®ééï¼æ°æ®ååï¼åºç¡æ¶æï¼æ°æ®å¤çï¼ç»è®¡åæï¼æ°æ®ææï¼æ¨¡åé¢æµï¼ç»æåç°ã
大æ°æ®åæææä¸å¤çã移å¨å¼åä¸æ¶æã软件å¼åãäºè®¡ç®çå沿ææ¯çã
主修课ç¨ï¼é¢å对象ç¨åºè®¾è®¡ãHadoopå®ç¨ææ¯ãæ°æ®ææãæºå¨å¦ä¹ ãæ°æ®ç»è®¡åæãé«çæ°å¦ãPythonç¼ç¨ãJAVAç¼ç¨ãæ°æ®åºææ¯ãWebå¼åãLinuxæä½ç³»ç»ã大æ°æ®å¹³å°æ建åè¿ç»´ã大æ°æ®åºç¨å¼åãå¯è§å设计ä¸å¼åçã
æ¨å¨å¹å »å¦çç³»ç»ææ¡æ°æ®ç®¡çåæ°æ®æææ¹æ³ï¼æä¸ºå ·å¤å¤§æ°æ®åæå¤çãæ°æ®ä»åºç®¡çã大æ°æ®å¹³å°ç»¼åé¨ç½²ã大æ°æ®å¹³å°åºç¨è½¯ä»¶å¼ååæ°æ®äº§åçå¯è§åå±ç°ä¸åæè½åçé«çº§ä¸ä¸å¤§æ°æ®ææ¯äººæã
()äºè®¡å课ç¨æ©å±é 读ï¼
åºç¨é¢å
大æ°æ®ææ¯è¢«æ¸éå°ç¤¾ä¼çæ¹æ¹é¢é¢ï¼å»çå«çãåä¸åæãå½å®¶å®å ¨ãé£åå®å ¨ãéèå®å ¨çæ¹é¢ãå¹´ï¼ä»å¤§æ°æ®ä½ä¸ºå½å®¶éè¦çæç¥èµæºåå å¿«å®ç°åæ°åå±çé«åº¦ï¼å¨å ¨ç¤¾ä¼å½¢æâç¨æ°æ®æ¥è¯´è¯ãç¨æ°æ®æ¥ç®¡çãç¨æ°æ®æ¥å³çãç¨æ°æ®æ¥åæ°âçæåæ°å´ä¸æ¶ä»£ç¹å¾ã
大æ°æ®ç§å¦å°æ为计ç®æºç§å¦ã人工æºè½ææ¯ï¼èæç°å®ãåä¸æºå¨äººãèªå¨é©¾é©¶ãå ¨è½çèªç¶è¯è¨å¤çï¼ãæ°åç»æµååä¸ãç©èç½åºç¨ãè¿æå个人æ社ç§é¢ååå±çæ ¸å¿ã
关于linux学习路线的问题 请教前辈
很多同学接触Linux不多,对Linux平台的码编开发更是一无所知。而现在的源译趋势越来越表明,作为一 个优秀的码编软件开发人员,或计算机IT行业从业人员,源译掌握Linux是码编软件源码管理一种很重要的谋生资源与手段。下来我将会结合自己的源译几年的个人开发经验,及对 Linux,码编更是源译类UNIX系统,及开源软件文化,码编谈谈Linux的源译学习方法与学习中应该注意的一些事。
就如同刚才说的码编,很多同学以前可能连Linux是源译什么都不知道,对UNIX更是码编一无所知。所以我们从最基础的源译讲起,对于Linux及UNIX的历史我们不做多谈,直接进入入门的学习。
Linux入门是很简单的,问题是你是否有耐心,是否爱折腾,是否不排斥重装一类的大修。没折腾可以说是学不好Linux的,鸟哥说过,要真正了解Linux的分区机制,对LVM使用相当熟练,没有次以上的Linux装机经验是积累不起来的,所以一定不要怕折腾。
由于大家之前都使用Windows,所以我也尽可能照顾这些“菜鸟”。我的推荐,如果你第一次接触Linux,那么首先在虚拟机中尝试它。虚拟机我推荐Virtual Box,我并不主张使用VM,原因是VM是闭源的,并且是收费的,我不希望推动盗版。当然如果你的Money足够多,可以尝试VM,但我要说的是即使是VM,不一定就一定好。付费的软件不一定好。首先,spyder 源码语言Virtual Box很小巧,Windows平台下安装包在MB左右,而VM动辄MB,虽然功能强大,但资源消耗也多,何况你的需求Virtual Box完全能够满足。所以,还是自己选。如何使用虚拟机,是你的事,这个我不教你,因为很简单,不会的话Google或Baidu都可以,英文好的可以直接看官方文档。
现在介绍Linux发行版的知识。正如你所见,Linux发行版并非Linux,Linux仅是指操作系统的内核,作为科班出生的你不要让我解释,我也没时间。我推荐的发行版如下:
UBUNTU适合纯菜鸟,追求稳定的官方支持,对系统稳定性要求较弱,喜欢最新应用,相对来说不太喜欢折腾的开发者。
Debian,相对UBUNTU难很多的发行版,突出特点是稳定与容易使用的包管理系统,缺点是企业支持不足,为社区开发驱动。
Arch,追逐时尚的开发者的首选,优点是包更新相当快,无缝升级,一次安装基本可以一直运作下去,没有如UBUNTU那样的版本概念,说的专业点叫滚动升级,保持你的系统一定是最新的。缺点显然易见,不稳定。同时安装配置相对Debian再麻烦点。
Gentoo,vue源码深挖相对Arch再难点,考验使用者的综合水平,从系统安装到微调,内核编译都亲历亲为,是高手及黑客显示自己技术手段,按需配置符合自己要求的系统的首选。
Slackware与Gentoo类似。
CentOS,社区维护的RedHat的复刻版本,完全使用RedHat的源码重新编译生成,与RedHat的兼容性在理论上来说是最好的。如果你专注于Linux服务器,如网络管理,架站,那么CentOS是你的选择。
LFS,终极黑客显摆工具,完全从源代码安装,编译系统。安装前你得到的只有一份文档,你要做的就是照文档你的说明,一步步,一条条命令,一个个软件包的去构建你的Linux,完全由你自己控制,想要什么就是什么。如果你做出了LFS,证明你的Linux功底已经相当不错,如果你能拿LFS文档活学活用,再将Linux从源代码开始移植到嵌入式系统,我敢说中国的企业你可以混的很好。
你得挑一个适合你的系统,然后在虚拟机安装它,开始使用它。如果你想快速学会Linux,我有一个建议就是忘记图形界面,不要想图形界面能不能提供你问题的答案,而是满世界的去找,去问,如何用命令行解决你的问题。在这个过程中,你最好能将Linux的逆向指标源码命令掌握的不错,起码常用的命令得知道,同时建立了自己的知识库,里面是你积累的各项知识。
再下个阶段,你需要学习的是Linux平台的C/C++开发,同时还有Bash脚本编程,如果你对Java兴趣很深还有Java。同样,建议你抛弃掉图形界面的IDE,从VIM开始,为什么是VIM,而不是Emacs,我无意挑起编辑器大战,但我觉得VIM适合初学者,适合手比较笨,脑袋比较慢的开发者。Emacs的键位太多,太复杂,我很畏惧。然后是GCC,Make,Eclipse(Java,C++或者)。虽然将C++列在了Eclipse中,但我并不推荐用IDE开发C++,因为这不是Linux的文化,容易让你忽略一些你应该注意的问题。IDE让你变懒,懒得跟猪一样。如果你对程序调试,测试工作很感兴趣,GDB也得学的很好,如果不是GDB也是必修课。这是开发的第一步,注意我并没有提过一句Linux系统API的内容,这个阶段也不要关心这个。你要做的就是积累经验,在Linux平台的开发经验。我推荐的书如下:C语言程序设计,谭浩强的也可以。C语言,白皮书当然更好。apk源码注解C++推荐C++ Primer Plus,Java我不喜欢,就不推荐了。工具方面推荐VIM的官方手册,GCC中文文档,GDB中文文档,GNU开源软件开发指导(电子书),汇编语言程序设计(让你对库,链接,内嵌汇编,编译器优化选项有初步了解,不必深度)。
如果你这个阶段过不了就不必往下做了,这是底线,最基础的基础,否则离开,不要霍霍Linux开发。不专业的Linux开发者作出的程序是与Linux文化或UNIX文化相背的,程序是走不远的,不可能像Bash,VIM这些神品一样。所以做不好干脆离开。
接下来进入Linux系统编程,不二选择,APUE,UNIX环境高级编程,一遍一遍的看,看遍都嫌少,如果你可以在大学将这本书翻烂,里面的内容都实践过,有作品,你口头表达能力够强,你可以在面试时说服所有的考官。(可能有点夸张,但APUE绝对是圣经一般的读物,即使是Windows程序员也从其中汲取养分,Google创始人的案头书籍,扎尔伯克的床头读物。)
这本书看完后你会对Linux系统编程有相当的了解,知道Linux与Windows平台间开发的差异在哪?它们的优缺点在哪?我的总结如下:做Windows平台开发,很苦,微软的系统API总在扩容,想使用最新潮,最高效的功能,最适合当前流行系统的功能你必须时刻学习。Linux不是,Linux系统的核心API就来个,记忆力好完全可以背下来。而且经久不变,为什么不变,因为要同UNIX兼容,符合POSIX标准。所以Linux平台的开发大多是专注于底层的或服务器编程。这是其优点,当然图形是Linux的软肋,但我站在一个开发者的角度,我无所谓,因为命令行我也可以适应,如果有更好的图形界面我就当作恩赐吧。另外,Windows闭源,系统做了什么你更本不知道,永远被微软牵着鼻子跑,想想如果微软说Win8不支持QQ,那腾讯不得哭死。而Linux完全开源,你不喜欢,可以自己改,只要你技术够。另外,Windows虽然使用的人多,但使用场合单一,专注与桌面。而Linux在各个方面都有发展,尤其在云计算,服务器软件,嵌入式领域,企业级应用上有广大前景,而且兼容性一流,由于支持POSIX可以无缝的运行在UNIX系统之上,不管是苹果的Mac还是IBM的AS系列,都是完全支持的。另外,Linux的开发环境支持也绝对是一流的,不管是C/C++,Java,Bash,Python,PHP,Javascript,。。。。。。就连C#也支持。而微软除Visual Stdio套件以外,都不怎么友好,不是吗?
如果你看完APUE的感触有很多,希望验证你的某些想法或经验,推荐UNIX程序设计艺术,世界顶级黑客将同你分享他的看法。
现在是时候做分流了。 大体上我分为四个方向:网络,图形,嵌入式,设备驱动。
如果选择网络,再细分,我对其他的不是他熟悉,只说服务器软件编写及高性能的并发程序编写吧。相对来说这是网络编程中技术含量最高的,也是底层的。需要很多的经验,看很多的书,做很多的项目。
我的看法是以下面的顺序来看书:
APUE再深读 – 尤其是进程,线程,IPC,套接字
多核程序设计 - Pthread一定得吃透了,你很NB
UNIX网络编程 – 卷一,卷二
TCP/IP网络详解 – 卷一 再看上面两本书时就该看了
5.TCP/IP 网络详解 – 卷二 我觉得看到卷二就差不多了,当然卷三看了更好,努力,争取看了
6.Lighttpd源代码 - 这个服务器也很有名了
7.Nginx源代码 – 相较于Apache,Nginx的源码较少,如果能看个大致,很NB。看源代码主要是要学习里面的套接字编程及并发控制,想想都激动。如果你有这些本事,可以试着往暴雪投简历,为他们写服务器后台,想一想全球的魔兽都运行在你的服务器软件上。
Linux内核 TCP/IP协议栈 – 深入了解TCP/IP的实现
如果你还喜欢驱动程序设计,可以看看更底层的协议,如链路层的,写什么路由器,网卡,网络设备的驱动及嵌入式系统软件应该也不成问题了。
当然一般的网络公司,就算百度级别的也该毫不犹豫的雇用你。只是看后面这些书需要时间与经验,所以岁以前办到吧!跳槽到给你未来的地方!
图形方向,我觉得图形方向也是很有前途的,以下几个方面。
Opengl的工业及游戏开发,国外较成熟。
影视动画特效,如皮克斯,也是国外较成熟。
GPU计算技术,可以应用在浏览器网页渲染上,GPU计算资源利用上,由于开源的原因,有很多的文档程序可以参考。如果能进火狐开发,或google做浏览器开发,应该会很好 。
嵌入式方向:嵌入式方向没说的,Linux很重要。
掌握多个架构,不仅X的,ARM的,单片机什么的也必须得懂。硬件不懂我预见你会死在半路上,我也想走嵌入式方向,但我觉得就学校教授嵌入式的方法,我连学电子的那帮学生都竞争不过。奉劝大家,一定得懂硬件再去做,如果走到嵌入式应用开发,只能祝你好运,不要碰上像Nokia,Hp这样的公司,否则你会很惨的。
驱动程序设计:软件开发周期是很长的,硬件不同,很快。每个月诞生那么多的新硬件,如何让他们在Linux上工作起来,这是你的工作。由于Linux的兼容性很好,如果不是太低层的驱动,基本C语言就可以搞定,系统架构的影响不大,因为有系统支持,你可能做些许更改就可以在ARM上使用PC的硬件了,所以做硬件驱动开发不像嵌入式,对硬件知识的要求很高。可以从事的方向也很多,如家电啊,特别是如索尼,日立,希捷,富士康这样的厂子,很稀缺的。
LDD – Linux驱动程序设计与内核编程的基础读物
深入理解Linux内核 – 进阶的
Linux源代码 – 永无止境的
当然你还的看个方面的书,如网络啊什么的。
mycat 高可用
mycat 高可用
mycat 可通过 zookeeper 集群进行配置文件管理。
1.1 搭建 zookeeper 集群
此处不做 zookeeper集群搭建讲解
1.2 配置mycat支持zookeeper
修改 mycat conf 目录下myid.properties
loadZk=true # zk集群地址,多个用","隔开 zkURL=..3.:,..3.:,..3.: # zk集群内Mycat集群ID clusterId=mycat-cluster-1 # Mycat集群内本实例ID,禁止重复 myid=mycat_fz_ # Mycat集群内节点个数 clusterSize=3 #集群内所有节点的 id clusterNodes=mycat_fz_,mycat_fz_,mycat_fz_ #server booster ; booster install on db same server,will reset all minCon to 1 type=server boosterDataHosts=dataHost1
1.3 自定义配置
将需要修改的配置文件替换到 conf 目录中的 zkconf 目录下,只需要在一台机器修改即可,需要注意 conf目录中的 server.xml 中用户名和密码与 zkconf 中的不一致
1.4 上传配置
执行修改了配置文件的 mycat 下的bin 目录下的initzkdata.sh,上传配置文件,(在修改了配置文件的机器上执行)
./initzkdata.sh
1.5 启动所有 mycat
启动后发现其他 mycat conf 下的配置文件已经自动变化为修改的内容,是zookeeper 中下载的
2. 使用的是 lvs+keepalived 的方式
此处使用的是 lvs+keepalived 的方式实现mycat高可用负载均衡集群
2.1 配置环境
角色 主机IP 主机名 操作系统版本 软件版本
VIP ..3.
LVS-DR-Master ..3. keepalived CentOS6.9 Keepalived v1.2.,LVS 1.2.1
LVS-DR-Backup ..3. keepalived CentOS6.9 Keepalived v1.2.,LVS 1.2.1
mycat-Realserver ..3. mycat CentOS6.9 mycat v1.6.5
mycat-Realserver ..3. mycat CentOS6.9 mycat v1.6.5
mycat-Realserver ..3. mycat CentOS6.9 mycat v1.6.5
2.2 安装keepalived和ipvsadm
注意:ipvsadm并不是lvs,它只是lvs的配置工具。在 CentOS1.1 的内核版本中是默认支持的。因此,这里不需要重新安装。使用 yum 的安装方式,分别在 keepalived 和 keepalived 两台主机上安装 keepalived 和 ipvsadm。除了这种简易方式外,也可直接编译官方的源码包。安装步骤可参考文档。
2.3 配置Keepalived
2.3.1 master
vi /etc/keepalived/keepalived.conf
配置详细内容如下,注意优先级、状态、接口、虚拟IP地址、负载调度算法、服务器节点配置、检查间隔、会话保持时间、协议类型等参数设置。
2.3.2 backup
备份机配置与主机一致,除了优先级和状态修改外。
在配置文件中,特别需要注意的是interface的修改,根据实际情况进行相应的修改。
2.4 安装配置 mycat
安装mycat请参考相关文档。
2.4.1 绑定虚拟 vip
在mycat服务器上为lo:0绑定VIP地址、抑制ARP广播。
执行脚本./realserver.sh start在mycat和mycat、mycat三台主机上。
2.4.2 查看
运行 ifconfig 查看结果。
2.5 启动 keeplive
分别在keepalived和keepalived上启动Keepalived服务。
2.5.1 查看
通过ipvsadm -L 查看映射。
2.5.2 测试
通过一台装有 mysql的机器连接虚拟 ip 发现可以登录数据库。
2.5.3 查看转发
再次在 keepalived 的机器执行ipvsadm -L,发现被转到上面一次。
2.5.4 负载均衡方式
与配置相关,多次都指向一个机器,因为我们在 keepalived 的配置文件中persistence_timeout属性指定为,则代表秒内同一个机器来的请求会被 hash 一致性分配。如果想实现严格意义上面的轮询,修改为0即可。