1. 程式人生 > >Java遊戲伺服器成長之路——感悟篇

Java遊戲伺服器成長之路——感悟篇

又是一個美好的週末啊,現在一到週末,早上就起得晚,下午困了又會睡一兩個小時,上班的時候,早上起來喝一杯咖啡,然後就能高效的工作一整天,然而到了週末人就懶散了,哈哈。
最近剛跳槽,到新公司已經幹了有兩週時間了,這兩週時間是過得比較充實的,因為這家新公司是個小公司,以前以單機開發為主,伺服器方面我一個人,做兩個遊戲的伺服器開發工作,當然,一個很簡單,另一個就相對複雜點,簡單的那個是個弱聯網遊戲,伺服器只需要做好資料存檔和登入支付驗證就好了,而另一個,則是相對複雜的slg遊戲,我感覺這是又一款cok,而公司目前並不打算再招伺服器了,所以估計這個專案我會一個人幹到明年吧,等第一款上線賺錢了,可能會再招伺服器。老實說,面試的時候,我就覺得這份工作對我而言是一個挑戰,而當我清楚的瞭解了公司狀況之後,我依然決定接受這個挑戰。
說說我之前的經歷吧,大四的時候,學校安排來北京培訓java(培訓沒什麼丟臉的,出來找工作我也用的真學歷真背景,不像某峰互聯),之後我去了培訓機構推薦的公司實習,那個時候,工資2k,然而工作也乾得很開心,跟著前輩學到了不少東西,當時是做微信公眾號開發的,我跟著前輩做微信後臺開發,當時使用SpringMVC+MyBatis框架,剛接觸的時候,我自己學了挺久才弄明白,後來弄明白之後想想,其實挺簡單,對於邏輯開發的程式設計師來說,你只需要弄懂工作流程就好了,頁面怎麼跳轉,跳轉怎麼傳值,資料怎麼處理,這些足夠了,當然我是個不滿足的人,我會去弄明白,為什麼用這個框架、為什麼不用別的、用這個有什麼好處、如果讓我自己來做這個後臺、我會怎麼搭建?帶著這些問題,我會試著自己搭建一下後臺框架(雖然前期大部分是複製貼上)。除了框架部分,微信高階介面也是我研究的重點,我會去官方文件看看微信是怎麼接入的,然後研究研究前輩的程式碼是怎麼寫的,所謂的幹一行愛一行大概就是這樣吧,當時我覺得,微信開發,是很有前途的,而我們公司用的框架,也是最先進的(後來看來,確實這個框架組合是當前最流行的框架,而當時,微信公眾號也確實是當時網際網路行業的一個風口,微信後來把h5帶起來了,導致現在一個好的h5前端都是供不應求的,薪資很高)。
說了這麼多,為什麼後來又轉行做遊戲了呢?其實是這樣的,當時在第一家公司,我的上級打算跳槽走了,帶走整個下面的技術,而不帶實習生,有那麼一兩個月,實習生就一直閒著沒事做,對於我來說,這樣過著就太無聊了,我喜歡挑戰,於是我投簡歷,重新找了份實習工作,在一個遊戲公司做java伺服器開發,公司挺大的,幾年前憑藉一款slg頁遊稱霸遊戲行業(什麼遊戲我就不說了,說了就知道什麼公司了),後來遊戲行業往手遊發展,這款slg也出了手遊版,這一款遊戲,幾乎支撐了整個公司,再加上後來出的幾款手遊,公司發展挺好的,我所實習的部門做的是一款mmorpg手遊,從實習做到了轉正,做了近一年了,然而這款rpg手遊的資料卻不是太好,第一次封測次日留存23,第二次26(現在這家公司的遊戲能達到80多次日留存),七日就更不用說了,而我也能感覺到,作為一款mmo遊戲,玩家之間的互動實在太少,從頭玩下來,我覺得這是一款單機,失去了mmo的本質,在專案組準備進行第三次封測的時候,我選擇了離開,原因很多,不僅僅因為遊戲資料不好,也有一些個人原因吧,不過說實話,是這家公司帶我走進了遊戲行業,我很感謝,我覺得遊戲行業是一個非常有前景的行業,甚至比之前我認為最好的微信開發還要好,遊戲行業非常暴利,在這家公司工作就能感受到,策劃文件中,充滿了挖坑預留的計費點,這一塊可以正常玩兒,但你如果充錢,你就比別人牛逼。網路遊戲,最重要的,就是控制好平民玩家跟普通玩家的佔比以及遊戲平衡(當意識到公司的遊戲如此處心積慮想要坑錢的時候,我突然明白為什麼公司的遊戲大多被騰訊代理了,為什麼騰訊控股,原來如此,沒錢玩兒你**,哈哈)。由此也可以看出,遊戲的商業化,已經把遊戲公司帶入了一個固定的模式——無條件坑錢,我覺得已經失去了遊戲的本質,我看過一本書,叫《遊戲人生》(當時在cocos2014年開發者大會上買的。覺得挺值的),書已經送人了,但內容我看了一大半,從遊戲的產生,到玩家的心理,到為什麼需要遊戲,這本書都詮釋的熱別好(我覺得遊戲策劃都應該看看這本書,做良心遊戲,拒絕一味坑錢)。啊,突然發現這一段說的有點偏了,說到底,我也只是做遊戲伺服器開發的,我也改變不了遊戲行業,我只要做好我做的。其實大的遊戲公司,就應該走這種商業化路線,憑藉幾款長生命週期的遊戲,支撐公司流水。
從轉行做遊戲之後,我倒是覺得,遊戲開發比web開發有趣多了,當然技術上也比web難多了,之前發過一篇討論,web開發何和遊戲開發的區別,

http://gad.qq.com/content/wendetail/7082370,我把我的答案再貼上一遍(實際上是別人要求我上他的號去回答的,於是我就自己回答了我自己的問題):
1.從第三方支援來說,web後臺有很多成熟的第三方框架,開發者不需要關心底層控制器跳轉的實現,只需要一個或幾個配置檔案,就能完成核心控制器的部分,而開發者只需要關注web自身的業務邏輯,將邏輯與框架融合即可,使用框架一方面簡化控制層程式碼,一方面很好的實現了業務邏輯的分層。而遊戲後臺開發中,因為各種遊戲的需求差異性很大,從網路層,到業務邏輯層,各方面都必須根據自己遊戲需求搭建適合自己的框架,因此很難有一些通用的東西能提煉出來一款成熟的框架,遊戲後臺開發基本上需要自己搭建適合自己的框架。
2.從業務邏輯層面來說,web後臺基本上邏輯都是大同小異的,或許這一套系統,稍微改改,另一套系統就能用,而遊戲就不同了,每個遊戲都有自己的特色,根據策劃的不同需求而實現不同的邏輯,不過也會有一些通用的模組,但整體上差異性還是很大的。
3.從資料持久化來說,web的資料基本上是很規整的,表與表之間關係很明確,並且以後也不會有太大的變化,而遊戲中的資料多種多樣,隨著開服之後,資料的變化也是多種多樣,甚至傳統的關係型資料庫根本無法滿足遊戲資料持久化的需求,遊戲中有很多狀態和資料是需要伺服器來儲存的,我個人認為,在遊戲開發中,nosql比關係型資料庫更實用。
4.從通訊層來說,web中的使用者都是一個個獨立的個體,而遊戲中是多人線上的一個遊戲世界,在這個遊戲世界中,玩家與玩家之間需要進行互動,這就需要伺服器實時的向所有線上玩家進行訊息廣播,這一點很損耗伺服器效能的,在這方面,遊戲後臺要比web做更多的處理,遊戲伺服器是一個IO密集的伺服器型別。
以上便是我當時的答案,或許我的見解尚淺,畢竟我做遊戲不到一年,不過對於後臺開發這塊,我還是有一點話語權的,從實習遊戲開發開始,我便經歷了一個轉換的過程,幾乎又是一個從零開始的學習過程,從mina框架到protobuffer,這些東西,我相信web開發很少接觸(mina作為網路通訊框架,web中幾乎只有http通訊,protobuffer作為通訊協議,web最多用json,其實二者形式上差別不大,但資料大小千差萬別)。而遊戲的邏輯,也是比web複雜得多,不得不說,web後臺成熟的第三方框架是做的真的很好。
經歷了上家公司的洗禮,我想我對遊戲後臺開發有了足夠的瞭解,於是我找到了我現在這家公司,這家公司目前只有我一個伺服器後臺,做兩款遊戲,一款是塔防類,準備由單機改成弱聯網,伺服器存檔,並做登入支付驗證,另一款,是比較龐大的slg手遊,是準備帶領公司走上巔峰的專案,說一款slg帶領一個公司走上巔峰一點兒不為過,我上家公司就是這樣的,憑藉一款《xxxx》(哈哈,名字不透露),走上人生巔峰。我之所以接受這份工作,是因為我接受挑戰,從底層寫起,從架構寫起,這是作為一年工作經驗的我想都不敢想的,不過這是一個挑戰自我,證明自我的機會,我願意接受這個挑戰,人生總會有很多爬坑的時候,但爬過了坑,就真的是人生巔峰了。我接受這個工作的另一個原因,就是公司發展確實不錯,以前做的單機,都是很火的(雖然我認為我自己一個人也能做,我也是學過cocos的),而現在公司也準確的把握了遊戲行業的風口——slg,coc和cok的成功案例就能證明一切,mmorpg也不一定能做起來了,moba倒是有可能,但你要跟lol做不到80%的相似,我估計沒人願意在手機玩兒moba,slg或許是價效比最高的了。這麼有挑戰的工作,還要從架構寫起,這樣的挑戰,我喜歡!
說說網際網路業的書吧,我認為這個行業的書,分為兩種,理論型的和技術型的,所謂理論型,就是長篇大論網際網路發展,行業模式等,而技術型,就是類似技術的工具書,是從技能入手的書,這兩種書,我家裡都有,但我發現買了之後,我很少有時間看,下班沒多少時間,北京上班,大多數時間都浪費在地鐵上了,上班時間,看看理論型的吧,覺得囉嗦,浪費時間(後來我發現,做這行,除了會技術,你還是需要去看看牛人眼中的網際網路的,你需要透過前輩的眼光看世界,不要做IT民工,要做網際網路從業者),看看技術型的吧,讓別人看見了感覺你太low,所以我大多數時間還是能在網上down到pdf就在電腦看,down不到百度谷歌我要研究的技術,畢竟從事這行,還是用電腦學技術好點,主要是電腦看久了眼睛會疲憊,偶爾看看紙質的書也不錯的。而以前面試的時候,面試官經常問,除了大學課本,你還看什麼書啊?(如果是你們,恰巧又沒看什麼書,你們怎麼說?),我一般會說,我會自學其他技術,如cocos2dx,然後買一些技術指南之類的書看。我覺得這已經算最大誇張化了,因為大學我真的很少看書,我記憶中就看過一本C++技術類的,一本C#的,一本Android,還有其他幾本是什麼都不大記得了,大學畢竟十幾層的圖書館,除了英語四六級的時候進去複習,其他時間感覺都浪費了這十幾層的圖書館。
說說成長過程中遇到的問題吧,如果遇到我解決不了的,以前是先自己百度谷歌,看看有沒有辦法解決,不行就問老大,而現在,先百度谷歌,看有沒有辦法解決,沒辦法在百度谷歌,實在不行還要看框架原始碼如何實現,上國外論壇看外國友人如何解決,問題總能解決的,總會有辦法的。當我開始學習寫架構的時候,我會開始關心遊戲的網路層使用什麼框架,mina還是netty,資料怎麼儲存mysql還是mongo,是否需要快取redis存什麼,memcached存什麼,快取什麼資料,資料傳輸用什麼協議,json還是protobuffer,怎麼寫效率高,最高支援多少併發等等,我想這些都是我現在需要考慮的問題,當然這些都需要根據遊戲具體的需求來決定的,最終伺服器能否高效穩定的執行,都是取決於我的架構是否高效穩定,所以這個過程我要不斷學習,不斷吸取別人的經驗。剛到新公司的時候,我才體會到,自己寫程式碼其實也是一種挑戰,整個後端我自己一個人實現,程式碼是否規範,資料如何儲存,都是我說了算,我想我的程式碼不僅要高效,還要讓別人看得懂,後來的人能接著我的程式碼繼續寫下去。
最後說說Java的題外話,語言之爭,從未停過,為什麼有人擁護Java,有人擁護PHP,有人喜歡C#,有人喜歡C++,各個語言各有各的優勢,業餘時間,我也瞭解了不少其他語言,go,node.js我都有了解,我覺得go的語言層面支援協程併發以及node.js的非同步,都是很適合遊戲伺服器的,我特別看好node.js,非同步io真的是對遊戲伺服器很好的特性,並且加入對原聲js支援的mongo模組也是很方便的(上面我有說到,我相信nosql是很適合儲存遊戲資料的)。說到遊戲行業,我認為h5遊戲的發展也是越來越快了,上次白鷺的h5開發者生態大會我去了,白鷺的一整套工作流程,以及web vr,真的很令人興奮(第一輪抽獎我還抽了一個暴風魔鏡,哈哈!),另外,大會的模特挺漂亮,哈哈!2015年,網際網路行業也略呈下降趨勢了,不少創業公司面臨倒閉,泡沫經濟破滅,因為很多老闆抓不住當前經濟形勢,以為不管是啥,有個app就是創業了,其實全然不知一款app後面有多少運營模式、盈利模式,就像一句諷刺的話,“我有個絕壁好的idea,可以顛覆bat,什麼都不缺,就缺個程式設計師了,等等,千萬別告訴馬雲!”,哈哈,聽到這句話,當時我就笑了,估計好多倒閉的創業公司老闆都這麼想的吧,他們並不能抓住使用者真正的需求,只有抓住使用者真正的需求,才會抓住使用者的心,真正活下來的,才是使用者真正需要的,然而,相對來說,遊戲行業更是複雜多變,或許今天玩家喜歡這種遊戲,明天玩家就喜歡另一種遊戲了,就像我們永遠也想不到,flappy bird、圍住神經病貓這類的遊戲竟然能活起來,愚公移山竟然也能讓h5遊戲變為付費的可能。就像一句話,“只要站在風口上,豬也能飛起來!”,只要抓住了玩家此時此刻真正想要的,產品就一定能做起來。
不知不覺,又到晚上了,又要睡覺了,明天還要去加班,遊戲開發之路。Java架構之路,我在路上,我是何金成,我喂自己帶鹽!
以上是我入坑遊戲行業這麼久的一些個人感受,可能感悟尚淺,但都是我真實的內心感受,元旦我再來寫一篇技術篇,記錄我搭建遊戲伺服器架構踩過的一些坑。