為什么要架私服
??最近有天突然想玩wow凤价,但是現(xiàn)在的游戲太便當(dāng),又是月卡制拔创,興趣就沒那么大了利诺。突發(fā)奇想去玩私服,下好了客戶端進(jìn)去折騰了一會伏蚊。后來我又想立轧,為什么不自己架個私服玩呢格粪?以前雖然折騰過躏吊,但用得是一鍵安裝版。這次我決定自己從源碼搞起帐萎,于是選擇了用TrinityCore來搭建最經(jīng)典的3.3.5版本比伏,當(dāng)然這僅是我的個人觀點(diǎn):D。
我的環(huán)境
- 服務(wù)器:VirtualBox 里安裝的Ubuntu 17.10.1
- 客戶端:Windows 10
客戶端我下載的是國服的3.3.5a(13507)版本疆导。小版本號不一致沒有大礙赁项,后面會提到如何處理。下面說說服務(wù)器的搭建過程。
整個過程是按照 官方的安裝說明
所描述的步驟來進(jìn)行的悠菜。因?yàn)槲疫x的是 3.3.5 分支舰攒,所以里面關(guān)于 Master 分支的東西不用管。
服務(wù)器的軟件需求
這里是官網(wǎng)列出來的軟件方面的需求:
Processor with SSE2 support
Boost ≥ 1.56
MySQL ≥ 5.1.0
OpenSSL = 1.0.x
CMake ≥ 3.2.0
GCC ≥ 6.3.0 or Clang ≥ 3.5 (heavy recommended, especially on master branch)
zlib ≥ 1.2.7
可以看出悔醋,像 gcc 和 cmake 這種的都需要較新的版本才可以編譯摩窃。所以Ubuntu的版本最好是 16.04LTS 及以上。
- 執(zhí)行以下命令:
sudo apt-get install git clang cmake make gcc g++ libmysqlclient-dev libssl-dev libbz2-dev libreadline-dev libncurses-dev libboost-all-dev mysql-server p7zip -y sudo update-alternatives --install /usr/bin/cc cc /usr/bin/clang 100 sudo update-alternatives --install /usr/bin/c++ c++ /usr/bin/clang 100
服務(wù)器程序安裝
這里部分路徑芬骄,比如源碼下載猾愿、程序安裝的路徑都可以自己修改,這里只寫出核心步驟所以沒有做修改账阻。
-
先下載代碼:
cd ~/ git clone -b 3.3.5 git://github.com/TrinityCore/TrinityCore.git
-
編譯準(zhǔn)備蒂秘,生成 Makefile ,$USER 是自己的用戶名:
cd TrinityCore mkdir build cd build cmake ../ -DCMAKE_INSTALL_PREFIX=/home/$USER/server #定義安裝路徑
這里是另外一個使用 cmake 的例子:
#cmake ../ -DCMAKE_INSTALL_PREFIX=/home/$USER/server -DTOOLS=0 -DWITH_WARNINGS=1
其中
-DTOOLS=0
是不編譯地圖提取工具的選項淘太,如果已經(jīng)有地圖資源就加上這個選項姻僧。
其他選項說明在 這里 。 -
編譯核心代碼:
make -j8 #這里可以根據(jù)自己的cpu核心數(shù)修改 make install
這一步完成后蒲牧,二進(jìn)制文件會在
/home/$USER/server/bin
目錄下段化,配置會在/home/$USER/server/etc
目錄下。將 etc 目錄里的worldserver.conf.dist
和authserver.conf.dist
復(fù)制為worldserver.conf
和authserver.conf
造成。
關(guān)于代碼更新
官方說開發(fā)者一直在維護(hù)并且加入新的features显熏,所以需要的話可以更新代碼:
cd ~/TrinityCore/
git pull origin 3.3.5
更新完之后需要重新編譯安裝,然后重啟服務(wù)器晒屎。
安裝MySQL服務(wù)器
這一步?jīng)]什么特別的喘蟆,需要注意的是,MyISAM 和 InnoDB 引擎應(yīng)該都支持鼓鲁。
服務(wù)器數(shù)據(jù)提取
這一階段需要用 wow 的客戶端來提取相應(yīng)的資源文件蕴轨,提取時需要在客戶端的根目錄下執(zhí)行提取工具。因?yàn)槲业姆?wù)器和客戶端在兩個操作系統(tǒng)里骇吭,所以我采用的辦法是將 wow 客戶端所在的文件夾設(shè)置為虛擬機(jī)的共享文件夾橙弱,然后在這個目錄中進(jìn)行提取。設(shè)置共享文件夾的方法這里就不贅述了燥狰。
下面的示例均假設(shè)我的wow目錄在虛擬機(jī)里的目錄是~/wow_client/
棘脐。
提取資源文件:DBC, Maps, VMaps 和 MMaps
-
提取 DBC 和 Maps 文件:
cd ~/wow_client/ /home/<username>/server/bin/mapextractor mkdir /home/<username>/server/data cp -r dbc maps /home/<username>/server/data
拷貝結(jié)束后編輯data目錄里的
worldserver.conf
,找到DataDir
的那行龙致,修改為:DataDir = "../data"
-
Visual Maps (也就是vmaps蛀缝,非必須但是推薦):
這一步可能會花很長的時間,老機(jī)器可能需要好幾個小時目代,我的機(jī)器也用了大半個小時屈梁。
cd ~/wow_client/ /home/<username>/server/bin/vmap4extractor mkdir vmaps /home/<username>/server/bin/vmap4assembler Buildings vmaps cp -r vmaps /home/<username>/server/data
看到下面這個消息時證明提取完成了嗤练,這個警告可以忽略。
Processing Map 724 [################################################################] Extracting GameObject models...Extracting World\Wmo\Band\Final_Stage.wmo No such file. Couldn't open RootWmo!!! Done! Extract V4.00 2012_02. Work complete. No errors.
-
Movement Maps (也就是mmaps在讶,也是可選但推薦的):
這一步也會花很長的時間
cd ~/wow_client/ mkdir mmaps /home/<username>/server/bin/mmaps_generator cp -r mmaps /home/<username>/server/data
修改配置文件
在配置文件里找到LoginDatabaseInfo
, WorldDatabaseInfo
和 CharacterDatabaseInfo
的配置選項以及MySQL的登陸信息煞抬,以便服務(wù)器可以連接數(shù)據(jù)庫。
在新的配置里构哺,應(yīng)該有以下的值:
LoginDatabaseInfo = "127.0.0.1;3306;trinity;trinity;auth" #worldserver.conf
WorldDatabaseInfo = "127.0.0.1;3306;trinity;trinity;world" #worldserver.conf
CharacterDatabaseInfo = "127.0.0.1;3306;trinity;trinity;characters" #worldserver.conf
格式的含義如下:
Variablename = "MySQLIP;Port;Loginname;Password;database"
如果需要在局域網(wǎng)或者公網(wǎng)上搭建此疹,要將127.0.0.1修改為對應(yīng)的ip。
3306是mysql的默認(rèn)端口遮婶,如果修改過的話蝗碎,這里也要修改。
注意:
如果提取資源時選擇不提取vmaps或者mmaps旗扑,必須修改以下選項:
vmap.enableLOS = 1 – 設(shè)置為0
vmap.enableHeight = 1 – 設(shè)置為0
vmap.petLOS = 1 – 設(shè)置為0
vmap.enableIndoorCheck = 1 – 設(shè)置為0
mmap.enablePathFinding = 0 (默認(rèn)值 - 保持為0)
如果想使用vmaps或mmaps蹦骑,則這些值要再改成1.
對于大多數(shù)worldserver.conf
里的修改,可以在游戲里輸入.reload config
進(jìn)行熱更新臀防。
安裝數(shù)據(jù)庫
首先需要下載數(shù)據(jù)庫文件:3.3.5的完整sql里下載 TDB_full_335.63_2017_04_18.7z
眠菇。
要先執(zhí)行這個sql來創(chuàng)建數(shù)據(jù)庫和用戶:
https://github.com/TrinityCore/TrinityCore/blob/3.3.5/sql/create/create_mysql.sql
3.3.5主要需要3個數(shù)據(jù)庫, 作用如下:
auth - holds account data - usernames, passwords, GM access, realm information, etc.
characters - holds character data - created characters, inventory, bank items, auction house, tickets, etc.
world - holds game-experience content such as NPCs, quests, objects, etc
構(gòu)建數(shù)據(jù)庫
- 從解壓出來的7z包里把
TDB_world_
開頭的sql文件拷貝到 worldserver 的目錄下(不要改名)。 - 然后啟動worldserver袱衷,當(dāng)它問你要不要創(chuàng)建數(shù)據(jù)庫時回車捎废。
服務(wù)器創(chuàng)建好數(shù)據(jù)庫后會查找maps和vmaps,找不到就會退出致燥。
網(wǎng)絡(luò)
8085端口必須要打開登疗,以確保 authserver 可以接受連接。也可以使用別的端口嫌蚤,當(dāng)然相應(yīng)的配置都要修改辐益。
auth 數(shù)據(jù)庫中的 realmlist 表的 address 字段需要被設(shè)置正確。
最后的步驟
啟動服務(wù)器 & 添加賬號
依次啟動 authserver 和 worldserver脱吱。
-
在 worldserver 窗口里可以用gm指令智政,比如創(chuàng)建賬號。
-
account create <user> <pass>
其中user是賬號箱蝠,pass是密碼 -
account set gmlevel $account #level #realmid
可以用來設(shè)置account的gm等級续捂,等級0-3,3最高宦搬。realmid代表對應(yīng)區(qū)牙瓢,-1表示所有。
-
world數(shù)據(jù)庫里的command表里有所有的gm指令床三。這里有一份 在線版的gm指令 一罩。
客戶端設(shè)置
- 打開
realmlist.wtf
文件,在Data目錄或zhCN目錄中撇簿。找到 realmlist的字段改為:set realmlist 你的IP
- 如果想要用啟動器來啟動游戲的話聂渊,必須將patchlist的ip值設(shè)置成和realmlist的一樣。
最后的試煉:客戶端版本問題
因?yàn)槲业目蛻舳税姹臼?3507四瘫,和服務(wù)器的12340不是完全對應(yīng)的汉嗽,所以一開始驗(yàn)證一直失敗。后來查了半天找蜜,是因?yàn)榉?wù)器的authserver里沒有寫入13507對應(yīng)的信息饼暑。于是修改
src/server/authserver/Authentication/AuthCodes.cpp
中的PostBcAcceptedClientBuilds
數(shù)組,在里面加入{13507, 3, 3, 5, 'a'},
洗做,重新編譯authserver和worldserver弓叛。此時驗(yàn)證可以通過了,但是一直顯示服務(wù)器離線诚纸。查過之后發(fā)現(xiàn)是auth數(shù)據(jù)庫里realmlist的gamebuild字段的值不對應(yīng)撰筷。把這個值改為13507,重啟服務(wù)器就可以進(jìn)入游戲了畦徘。
大功告成挖函!
現(xiàn)在可以用前面創(chuàng)建的賬號登錄游戲并建角色饥漫,進(jìn)游戲后紀(jì)念一下。