一個自己實踐的微服務(wù)全家桶峡钓,希望能提供幫助

前奏

創(chuàng)業(yè)半年多,中間做過一個app若河。各種各樣的原因能岩,最后雖然上線了,但是沒有推廣萧福,每天百十來個用戶拉鹃,也不打算迭代了。我們后臺使用的是基于spring-boot鲫忍、spring-cloud的微服務(wù)框架膏燕。框架包含了spring-cloud全家桶的大部分組件悟民,我自己花時間坝辫,重新把這些框架類的內(nèi)容整理了一遍,構(gòu)建了一個簡單的場景射亏,開源出來近忙,希望對那些想學(xué)習(xí) 或者 快速搭建自己的微服務(wù)框架的同學(xué)能提供幫助。

代碼地址(附上原文地址):https://github.com/chxfantasy/spring-cloud-demo
截圖:

代碼目錄

如果對微服務(wù)本身不太太了解的話鸦泳,或者不知道為什么需要微服務(wù)的話,請參考原來的一篇文章:我也想寫篇微服務(wù)的文章永品,以及微服務(wù)的優(yōu)缺點

如果對微服務(wù)里面的各個組件不太熟悉的話做鹰,可以參考這一篇文章:spring cloud從看不懂到放棄

項目介紹

  1. 這僅僅是spring-cloud微服務(wù)框架的一個demo,可以完整運行鼎姐〖佤铮可能你初看到這里,會覺得這個項目目錄太tm復(fù)雜了炕桨,確實饭尝,微服務(wù)要做的就是解耦、輕量化献宫。這里面包含的組件和內(nèi)容有:
    • spring cloud eureka钥平,服務(wù)注冊和服務(wù)發(fā)現(xiàn)
    • spring cloud config,動態(tài)配置項
    • ribbon姊途,客戶端負載均衡
    • feign涉瘾,
    • hystrix知态,熔斷
    • turbine
    • Spring Cloud Starters
    • 同一個服務(wù)中的多數(shù)據(jù)庫支持(AOP)
    • 全鏈路traceId追蹤
    • velocity 前端模板
    • mybatis, pageHelper (分頁), druid (連接池)
    • redis(序列化采用的是jdk默認序列化方案)
    • slf4j & logback(及其配置)
    • 國際化配置
    • 全局錯誤信息catch
    • 線程池
    • 服務(wù)健康檢查, 服務(wù)全鏈路健康檢查
  2. 代碼的業(yè)務(wù)是:首先有一個登錄頁面,用戶登錄以后立叛,能看到一個微博(moment)列表负敏,同時也可以添加微博。在每個微博的最右邊秘蛇,可以看到每個微博的評論列表其做,也能添加評論。前端代碼寫的非常粗糙赁还。妖泄。。 如果你真的運行了秽浇,求不吐槽浮庐。
  3. 這里不談根據(jù)業(yè)務(wù)的需求去選擇是否微服務(wù)化,也不爭辯什么時候該用什么樣的框架柬焕,我這里只是把我們app后端的代碼审残,抽象成一個代碼庫,希望能為你提供幫助斑举。我們產(chǎn)品上線2個多月搅轿,后端基本沒有出過問題(也跟量小有關(guān)系)。

運行

  1. 首先富玷,你在本地需要有一個redis和mysql璧坟,redis默認啟動就可以。數(shù)據(jù)庫表的創(chuàng)建語句見下:
create database test;

CREATE TABLE `account` (
  `user_id` varchar(127) NOT NULL DEFAULT '',
  `user_name` varchar(127) NOT NULL DEFAULT '',
  `password` varchar(127) NOT NULL DEFAULT '',
  `gmt_created` datetime NOT NULL,
  `gmt_modified` datetime DEFAULT NULL,
  `is_deleted` tinyint(1) NOT NULL DEFAULT '0',
  PRIMARY KEY (`user_id`),
  KEY `index_user_id` (`user_id`) KEY_BLOCK_SIZE=10
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

CREATE TABLE `moment` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
  `user_id` varchar(127) COLLATE utf8mb4_unicode_ci NOT NULL,
  `content` text COLLATE utf8mb4_unicode_ci,
  `gmt_created` datetime NOT NULL,
  `gmt_modified` datetime DEFAULT NULL,
  `is_deleted` tinyint(1) DEFAULT '0',
  PRIMARY KEY (`id`),
  KEY `index_user_id` (`user_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

create database test2;

CREATE TABLE `comment` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
  `moment_id` bigint(20) unsigned NOT NULL,
  `content` text COLLATE utf8mb4_unicode_ci,
  `gmt_created` datetime NOT NULL,
  `gmt_modified` datetime DEFAULT NULL,
  `is_deleted` tinyint(1) DEFAULT '0',
  PRIMARY KEY (`id`),
  KEY `index_moment_id` (`moment_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  1. 系統(tǒng)環(huán)境需要Java 8 和 maven 3及以上
  2. 運行命令如下 (需要按順序運行每個模塊):
    cd spring-cloud-parent
    mvn clean install -DskipTests
    cd ../spring-cloud-client
    mvn clean install -DskipTests
    cd ../spring-cloud-starter
    mvn clean install -DskipTests
    
    cd spring-cloud-eureka
    mvn clean spring-boot:run
    
    cd spring-cloud-account
    mvn clean spring-boot:run
    
    cd spring-cloud-biz
    mvn clean spring-boot:run   
    
    cd spring-cloud-gateway
    mvn clean spring-boot:run
  1. 瀏覽器中打開 http://127.0.0.1:7001/index

代碼解釋

  1. 代碼中的依賴關(guān)系見下圖:


    代碼依賴關(guān)系
  2. spring-cloud-parent
    • 是一個空的mvn project, 包含了一些被其他項目所需要的公共的依賴赎懦。我這里創(chuàng)建parent雀鹃,僅僅是因為我不想把很多相同的依賴在spring-cloud-eureka、spring-cloud-biz励两、spring-cloud-account和spring-cloud-gateway這幾個項目中重復(fù)寫一遍黎茎,所以,一般微服務(wù)project都集成spring-cloud-parent当悔。嗯傅瞻,懶惰是人類的第一生產(chǎn)力。
  3. spring-cloud-starter
    • 是一個我創(chuàng)建的spring starter, 里面包含的是一些公共的bean盲憎,和一些公共的bean配置嗅骄,比如國際化locle配置、緩存CacheService配置饼疙,messageConvertor配置等溺森,spring-cloud-biz、spring-cloud-account和spring-cloud-gateway等微服務(wù)都需要依賴和共用這些基礎(chǔ)配置。
  4. spring-cloud-client
    • 是一個公共依賴儿惫,這里包含的是一個util類澡罚,以及多個模塊需要共同使用的、和數(shù)據(jù)庫表對應(yīng)的Java model.
  5. spring-cloud-eureka
    • 是一個服務(wù)注冊和服務(wù)發(fā)現(xiàn)中心肾请,需要集群化留搔。代碼里,我把spring-cloud-config動態(tài)配置項也集成在這里面了铛铁。服務(wù)發(fā)現(xiàn)的心跳檢測時間隔显,也從15s改到了5s,這對于快速發(fā)現(xiàn)節(jié)點故障很有作用饵逐。
  6. spring-cloud-account
    • 是整個工程的賬號服務(wù)模塊括眠。對于一個大型的系統(tǒng)來講,單獨的賬號服務(wù)系統(tǒng)是很有必要解耦出來的倍权。
  7. spring-cloud-biz
    • 是實際的業(yè)務(wù)模塊掷豺,包括發(fā)微博模塊和評論模塊。整個代碼中動態(tài)使用了兩個數(shù)據(jù)庫薄声,我這里對數(shù)據(jù)庫的切分只是簡單從業(yè)務(wù)上切分当船,既:微博在一個庫中,評論在另外一個庫中默辨,同時寫了一個@TargetDataSource注解德频,方便動態(tài)切換數(shù)據(jù)庫。其實對于分庫缩幸、分表壹置、讀寫分離,代碼都是類似的表谊。
  8. spring-cloud-gateway
    • 是整個系統(tǒng)的網(wǎng)關(guān)服務(wù)钞护,所有來自端上的請求,包括app或者web頁面爆办,都需要先到網(wǎng)關(guān)难咕,由網(wǎng)關(guān)做過處理之后再轉(zhuǎn)發(fā)給其他服務(wù)。比如押逼,網(wǎng)關(guān)需要處理登錄狀態(tài)問題步藕,需要處理上傳文件問題惦界,需要做一些過濾挑格,以及其他多種切面上的事情。
  9. 如果需要停止某個微服務(wù)沾歪,如spring-cloud-account漂彤、spring-cloud-biz或者spring-cloud-gateway, 運行命令: curl -H 'Accept:application/json' -X POST 'http://127.0.0.1:${management.port}/shutdown', 這條命令會先讓這個微服務(wù)在注冊中心下掉自己,然后再停掉自己。

部署

  1. 服務(wù)的部署如下圖:


    部署
  2. 需要注意的就是挫望,整個系統(tǒng)只有g(shù)ateway是可以被端訪問到的立润,其他服務(wù)的所有接口,都應(yīng)該只能在內(nèi)網(wǎng)訪問媳板,這也可以讓其他服務(wù)不做很強的權(quán)限驗證桑腮。
  3. 代碼里面細節(jié)很多,比如cache如何使用蛉幸, GlobalCacheHelper破讨,hystrix的自定義設(shè)置,全鏈路traceId的設(shè)置奕纫,信息的國際化提陶、健康檢查(去檢查了cache、db等其他項匹层,還檢查了每一項的返回時間)隙笆,這里沒辦法展開一一講解。有問題請直接github上開issue升筏,或者公眾號聯(lián)系我:不如假如撑柔。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市仰冠,隨后出現(xiàn)的幾起案子乏冀,更是在濱河造成了極大的恐慌,老刑警劉巖洋只,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件辆沦,死亡現(xiàn)場離奇詭異,居然都是意外死亡识虚,警方通過查閱死者的電腦和手機肢扯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來担锤,“玉大人蔚晨,你說我怎么就攤上這事「匮” “怎么了铭腕?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長多糠。 經(jīng)常有香客問我累舷,道長,這世上最難降的妖魔是什么夹孔? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任被盈,我火速辦了婚禮析孽,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘只怎。我一直安慰自己袜瞬,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布身堡。 她就那樣靜靜地躺著邓尤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪贴谎。 梳的紋絲不亂的頭發(fā)上裁赠,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天,我揣著相機與錄音赴精,去河邊找鬼佩捞。 笑死,一個胖子當(dāng)著我的面吹牛蕾哟,可吹牛的內(nèi)容都是我干的一忱。 我是一名探鬼主播,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼谭确,長吁一口氣:“原來是場噩夢啊……” “哼帘营!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起逐哈,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤芬迄,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后昂秃,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體禀梳,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年肠骆,在試婚紗的時候發(fā)現(xiàn)自己被綠了算途。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡蚀腿,死狀恐怖嘴瓤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情莉钙,我是刑警寧澤廓脆,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站磁玉,受9級特大地震影響停忿,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蜀涨,卻給世界環(huán)境...
    茶點故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一瞎嬉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧厚柳,春花似錦氧枣、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至碳想,卻和暖如春烧董,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背胧奔。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工逊移, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人龙填。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓胳泉,卻偏偏與公主長得像,于是被迫代替她去往敵國和親岩遗。 傳聞我的和親對象是個殘疾皇子扇商,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,779評論 2 354

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)宿礁,斷路器案铺,智...
    卡卡羅2017閱讀 134,654評論 18 139
  • 軟件是有生命的,你做出來的架構(gòu)決定了這個軟件它這一生是坎坷還是幸福梆靖。 本文不是講解如何使用Spring Cloud...
    Bobby0322閱讀 22,651評論 3 166
  • 轉(zhuǎn)自:https://my.oschina.net/CraneHe/blog/703181 最近一直在關(guān)注關(guān)于微服...
    艾爾溫閱讀 2,681評論 0 52
  • 有一個人 臉上常掛著微笑 無論痛苦或是悲傷 笑容從未消失 別人都很羨慕他 甚至有人嫉妒他過得那么幸福 就算是傷心難...
    杪夏蕶閱讀 309評論 0 0
  • (一) 有些人你以為此生都再無交集了控汉,卻會在平平常常的一個日子里,展開某種奇異的聯(lián)系返吻。 如果這是宇宙的力量暇番,那簡直...
    張成薇閱讀 318評論 0 1