redis集群操作

由于redis集群需要使用ruby命令,所以我們需要安裝ruby(所有的操作都是在單機(jī)部署的偽集群模式下進(jìn)行)

(1)yum?install?ruby

(2)yum?install?rubygems

(3)gem?install?redis?(安裝redis和ruby的接口)

一贰谣、原始集群(6節(jié)點(diǎn) 3主3從):

(1)啟動集群:

[root@centos~]#/usr/local/redis/bin/redis-server /usr/local/redis-cluster/7001/redis.conf

[root@ centos ~]#/usr/local/redis/bin/redis-server /usr/local/redis-cluster/7002/redis.conf

[root@ centos ~]# /usr/local/redis/bin/redis-server/usr/local/redis-cluster/7003/redis.conf

[root@ centos ~]#/usr/local/redis/bin/redis-server /usr/local/redis-cluster/7004/redis.conf

[root@ centos ~]#/usr/local/redis/bin/redis-server /usr/local/redis-cluster/7005/redis.conf

[root@ centos ~]# /usr/local/redis/bin/redis-server/usr/local/redis-cluster/7006/redis.conf

(2)查看服務(wù)器運(yùn)行狀態(tài):

[root@centos~]# ps -el | grep redis

5 S???? 0? 1999???? 1? 0? 80?? 0 - 34359 ep_pol ???????? 00:00:00 redis-server

5 S???? 0? 2003???? 1? 0? 80?? 0 - 34359 ep_pol ???????? 00:00:00 redis-server

5 S???? 0? 2007???? 1? 0? 80?? 0 - 34359 ep_pol ???????? 00:00:00 redis-server

5 S???? 0? 2011???? 1? 0? 80?? 0 - 34359 ep_pol ???????? 00:00:00 redis-server

5 S???? 0? 2017???? 1? 0? 80?? 0 - 34359 ep_pol ???????? 00:00:00 redis-server

5 S???? 0? 2023???? 1? 0? 80?? 0 - 34359 ep_pol ???????? 00:00:00 redis-server

(3)查看集群狀態(tài)


二倍啥、新集群操作

(1)我們新建倆個服務(wù)牌捷,按照之前搭建的集群方式新增倆個節(jié)點(diǎn):(一主一從 master乌助、slave)

????Master:7007??????????????? Slave:7008

步驟一:創(chuàng)建7007/7008文件夾萌京⊙媲幔拷貝redis.conf文件到對于的7007,7008目錄下要? ? ? ? ? ? ? ? ? ? ? ??

進(jìn)行修改配置文件数苫。

????[root@centos redis-cluster]# mkdir 7007

????[root@centos redis-cluster]# mkdir 7008

????[root@centos redis-cluster]# cd 7001

????[root@centos 7001]# cp redis.conf /usr/local/redis-cluster/7007/

????[root@centos 7001]# cp redis.conf /usr/local/redis-cluster/7008/

? ? ?[root@centos 7001]# vim/usr/local/redis-cluster/7007/redis.conf

修改內(nèi)容如下:

??????? ?port:7007

?????dir /usr/local/redis-cluster/7007/

?????cluster-config-file nodes7007.conf

??????? [root@centos 7001]# vim/usr/local/redis-cluster/7008/redis.conf

修改內(nèi)容如下:

??????? ?port:7008

?????dir /usr/local/redis-cluster/7008/

?????cluster-config-file nodes7008.conf


步驟二:啟動7007和7008倆個服務(wù)并查看服務(wù)狀態(tài)狭归。

[root@centos 7001]#/usr/local/redis/bin/redis-server /usr/local/redis-cluster/7007/redis.conf

[root@centos 7001]#/usr/local/redis/bin/redis-server /usr/local/redis-cluster/7008/redis.conf

[root@centos 7001]# ps -el | grep redis

(2)學(xué)習(xí)redis-trib命令使用:

[root@centos local]# cd/usr/local/redis3.0/src

[root@centos src]# redis-trib.rb


1 create:創(chuàng)建一個集群環(huán)境host1:port1 ... hostN:portN(集群中的主從節(jié)點(diǎn)比例)

2 call:可以執(zhí)行redis命令

3 add-node:將一個節(jié)點(diǎn)添加到集群里,第一個參數(shù)為新節(jié)點(diǎn)的ip:port文判,第二個參數(shù)為集群中任意一個已經(jīng)存在的節(jié)點(diǎn)的ip:port

4 del-node:移除一個節(jié)點(diǎn)

5 reshard:重新分片

6 check:檢查集群狀態(tài)

(3)新增一個主節(jié)點(diǎn)7007(master)

步驟一:使用add-node命令:綠色為新增節(jié)點(diǎn)过椎,紅色為已知存在節(jié)點(diǎn)

[root@centos 7001]#

/usr/local/redis3.0/src/redis-trib.rbadd-node192.168.1.171:7007192.168.1.171:7001


輸出如下:

>>> Addingnode 192.168.1.171:7007 to cluster 192.168.1.171:7001

Connecting to node192.168.1.171:7001: OK

Connecting to node192.168.1.171:7006: OK

Connecting to node192.168.1.171:7005: OK

Connecting to node192.168.1.171:7004: OK

Connecting to node192.168.1.171:7002: OK

Connecting to node192.168.1.171:7003: OK

>>> PerformingCluster Check (using node 192.168.1.171:7001)

M:614d0def75663f2620b6402a017014b57c912dad 192.168.1.171:7001

?? slots:0-5460 (5461 slots) master

?? 1 additional replica(s)

S:fa299e41c173fa807ba04684c2f5e5e185d5f7d0 192.168.1.171:7006

?? slots: (0 slots) slave

?? replicates83df08875c7707878756364039df0a4c8658f272

S:adb99506ddccad332e09258565f2e5f4f456a150 192.168.1.171:7005

?? slots: (0 slots) slave

?? replicates8aac82b63d42a1989528cd3906579863a5774e77

S:a69b98937844c6050ee5885266ccccb185a3f36a 192.168.1.171:7004

?? slots: (0 slots) slave

?? replicates614d0def75663f2620b6402a017014b57c912dad

M: 8aac82b63d42a1989528cd3906579863a5774e77192.168.1.171:7002

?? slots:5461-10922 (5462 slots) master

?? 1 additional replica(s)

M:83df08875c7707878756364039df0a4c8658f272 192.168.1.171:7003

?? slots:10923-16383 (5461 slots) master

?? 1 additional replica(s)

[OK] All nodes agreeabout slots configuration.

>>> Check foropen slots...

>>> Checkslots coverage...

[OK] All 16384 slotscovered.

Connecting to node192.168.1.171:7007: OK

>>> SendCLUSTER MEET to node 192.168.1.171:7007 to make it join the cluster.

[OK] New node added correctly.

步驟二:查看集群狀態(tài):

[root@centos src]#/usr/local/redis/bin/redis-cli -c -h 192.168.1.171 -p 7001

192.168.1.171:7001> cluster?nodes


注意:當(dāng)添加節(jié)點(diǎn)成功以后,新增的節(jié)點(diǎn)不會有任何數(shù)據(jù)戏仓,因為它沒有分配任何的slot(hash槽)疚宇。我們需要為新節(jié)點(diǎn)手工分配slot。

為7007分配slot槽赏殃。

步驟一:使用redis-trib命令敷待,找到集群中的任意一個主節(jié)點(diǎn)(紅色位置表現(xiàn)集群中的任意一個主節(jié)點(diǎn)),對其進(jìn)行重新分片工作仁热。

[root@centos 7001]#/usr/local/redis3.0/src/redis-trib.rb reshard192.168.1.171:7001


輸出如下:

>>> PerformingCluster Check (using node 192.168.1.171:7001)

M:614d0def75663f2620b6402a017014b57c912dad 192.168.1.171:7001

?? slots:0-5460 (5461 slots) master

?? 1 additional replica(s)

S:fa299e41c173fa807ba04684c2f5e5e185d5f7d0 192.168.1.171:7006

?? slots: (0 slots) slave

?? replicates83df08875c7707878756364039df0a4c8658f272

S:adb99506ddccad332e09258565f2e5f4f456a150 192.168.1.171:7005

?? slots: (0 slots) slave

?? replicates8aac82b63d42a1989528cd3906579863a5774e77

M:382634a4025778c040b7213453fd42a709f79e28 192.168.1.171:7007

?? slots: (0 slots) master

?? 0 additional replica(s)

S:a69b98937844c6050ee5885266ccccb185a3f36a 192.168.1.171:7004

?? slots: (0 slots) slave

?? replicates614d0def75663f2620b6402a017014b57c912dad

M:8aac82b63d42a1989528cd3906579863a5774e77 192.168.1.171:7002

?? slots:5461-10922 (5462 slots) master

?? 1 additional replica(s)

M:83df08875c7707878756364039df0a4c8658f272 192.168.1.171:7003

?? slots:10923-16383 (5461 slots) master

?? 1 additional replica(s)

[OK] All nodes agreeabout slots configuration.

>>> Check foropen slots...

>>> Checkslots coverage...

[OK] All 16384 slotscovered.

(提示一)

How many slots do you

want to move (from 1 to 16384)? 200

(提示二)

What is the receiving

node ID? 382634a4025778c040b7213453fd42a709f79e28

Please enter all thesource node IDs.

? Type 'all' to use all the nodes as sourcenodes for the hash slots.

? Type 'done' once you entered all the sourcenodes IDs.

Source node #1:all

Ready to move 200slots.

? Source

nodes:

??? M: 614d0def75663f2620b6402a017014b57c912dad192.168.1.171:7001

?? slots:0-5460 (5461 slots) master

?? 1 additional replica(s)

??? M: 8aac82b63d42a1989528cd3906579863a5774e77192.168.1.171:7002

?? slots:5461-10922 (5462 slots) master

?? 1 additional replica(s)

??? M: 83df08875c7707878756364039df0a4c8658f272192.168.1.171:7003

?? slots:10923-16383 (5461 slots) master

?? 1 additional replica(s)

? Destination

node:

??? M: 382634a4025778c040b7213453fd42a709f79e28192.168.1.171:7007

?? slots: (0 slots) master

?? 0 additional replica(s)

? Resharding plan:(分片執(zhí)行計劃日志)

Moving slot 5461 from8aac82b63d42a1989528cd3906579863a5774e77

...

Moving slot 0 from 614d0def75663f2620b6402a017014b57c912dad

...

??? Moving slot 10923 from83df08875c7707878756364039df0a4c8658f272

...

(提示三)

Do you want to

proceed with the proposed reshard plan (yes/no)? yes

Moving slot 65 from192.168.1.171:7001 to 192.168.1.171:7007:

...

Moving slot 10923 from 192.168.1.171:7003to 192.168.1.171:7007:

...

Moving slot 5527 from192.168.1.171:7002 to 192.168.1.171:7007:

...

1提示一:是希望你需要多少個槽移動到新的節(jié)點(diǎn)上榜揖,可以自己設(shè)置,比如200個槽抗蠢。

2提示二:是你需要把這200個slot槽移動到那個節(jié)點(diǎn)上去(需要指定節(jié)點(diǎn)id)举哟,并且下個????????????? ? 提示是輸入all為從所有主節(jié)點(diǎn)(7001 7002 7003)中分別抽取響應(yīng)的槽數(shù)(一共為200個槽到指定的新節(jié)點(diǎn)中!迅矛,并且會打印執(zhí)行分片的計劃妨猩。)

3提示三:輸入yes確認(rèn)開始執(zhí)行分片任務(wù)。在最后我們再次看一下集群狀態(tài):


如上圖所示秽褒,現(xiàn)在我們的7007已經(jīng)有slot槽了壶硅,也就是說可以在7007上進(jìn)行讀寫數(shù)據(jù)啦!到此為止我們的7007已經(jīng)加入到集群中啦销斟,并且是主節(jié)點(diǎn)(Master)

添加從節(jié)點(diǎn)(7008)到集群中去庐椒。

步驟一:還是需要執(zhí)行add-node命令:

[root@centos 7001]#/usr/local/redis3.0/src/redis-trib.rbadd-node 192.168.1.171:7008 192.168.1.171:7001

提示添加成功后我們繼續(xù)看一下集群的狀態(tài):

如圖所示,還是一個master節(jié)點(diǎn)蚂踊,沒有被分配任何的slot槽约谈。

步驟二:我們需要執(zhí)行replicate命令來指定當(dāng)前節(jié)點(diǎn)(從節(jié)點(diǎn))的主節(jié)點(diǎn)id為哪個。

首先需要登錄新加的7008節(jié)點(diǎn)的客戶端,然后使用集群命令進(jìn)行操作窗宇,把當(dāng)前的7008(slave)節(jié)點(diǎn)指定到一個主節(jié)點(diǎn)下(這里使用之前創(chuàng)建的7007主節(jié)點(diǎn),紅色表示節(jié)點(diǎn)id)

[root@centos ~]# /usr/local/redis/bin/redis-cli-c -h 192.168.1.171 -p 7008

192.168.1.171:7008> cluster replicate382634a4025778c040b7213453fd42a709f79e28

192.168.1.171:7008> OK(提示OK則操作成功)

我們繼續(xù)看一下當(dāng)前集群的狀態(tài)特纤,如下圖:我們已經(jīng)成功的把7008放到7007這個主節(jié)點(diǎn)下面了军俊,到此為止我們已經(jīng)成功的添加完一個從節(jié)點(diǎn)了。

我們可以對集群進(jìn)行操作捧存,來驗證下是否可以進(jìn)行讀寫(當(dāng)然可以)粪躬。

我們現(xiàn)在嘗試刪除一個節(jié)點(diǎn)(7008 slave)

步驟一:刪除從節(jié)點(diǎn)7008,輸入del-node命令昔穴,指定刪除節(jié)點(diǎn)ip和端口镰官,以及節(jié)點(diǎn)id(紅色為7008節(jié)點(diǎn)id)

[root@centos 7001]#/usr/local/redis3.0/src/redis-trib.rb

del-node 192.168.1.171:700897b0e0115326833724eb0ffe1d0574ee34618e9f

輸出如下:

>>> Removing node 97b0e0115326833724eb0ffe1d0574ee34618e9ffrom cluster 192.168.1.171:7008

Connecting to node 192.168.1.171:7008: OK

Connecting to node 192.168.1.171:7003: OK

Connecting to node 192.168.1.171:7006: OK

Connecting to node 192.168.1.171:7002: OK

Connecting to node 192.168.1.171:7005: OK

Connecting to node 192.168.1.171:7001: OK

Connecting to node 192.168.1.171:7004: OK

Connecting to node 192.168.1.171:7007: OK

>>> Sending CLUSTER FORGETmessages to the cluster...

>>> SHUTDOWN the node.

步驟二:再次查看一下集群狀態(tài),如下圖所示吗货,我們已經(jīng)成功的移除了7008 slave節(jié)點(diǎn)泳唠,另外我們發(fā)現(xiàn)移除一個節(jié)點(diǎn)以后,當(dāng)前節(jié)點(diǎn)的服務(wù)進(jìn)程也會隨之銷毀宙搬”啃龋可以使用ps命令查看當(dāng)前的服務(wù)(ps -el | grep

redis),發(fā)現(xiàn)少了一個運(yùn)行的server勇垛,也就是剛移除的7008從節(jié)點(diǎn)脖母。


最后,我們嘗試刪除之前加入的主節(jié)點(diǎn)7007

這個步驟會相對比較麻煩一些闲孤,因為主節(jié)點(diǎn)的里面是有分配了slot槽的谆级,所以我們這里必須先把7007里的slot槽放入到其他的可用主節(jié)點(diǎn)中去,然后再進(jìn)行移除節(jié)點(diǎn)操作才行讼积,不然會出現(xiàn)數(shù)據(jù)丟失問題肥照。

步驟一:刪除7007(master)節(jié)點(diǎn)之前,我們需要先把其全部的數(shù)據(jù)(slot槽)移動到其他節(jié)點(diǎn)上去(目前只能把master的數(shù)據(jù)遷移到一個節(jié)點(diǎn)上勤众,暫時做不了平均分配功能)建峭。

[root@centos 7001]#/usr/local/redis3.0/src/redis-trib.rb reshard 192.168.1.171:7007

輸出如下:

>>> Performing Cluster Check(using node 192.168.1.171:7007)

M:382634a4025778c040b7213453fd42a709f79e28 192.168.1.171:7007

?? slots:0-65,5461-5527,10923-10988 (199 slots) master

?? 0 additional replica(s)

S: fa299e41c173fa807ba04684c2f5e5e185d5f7d0192.168.1.171:7006

??slots: (0 slots) slave

??replicates 83df08875c7707878756364039df0a4c8658f272

S: a69b98937844c6050ee5885266ccccb185a3f36a192.168.1.171:7004

??slots: (0 slots) slave

??replicates 614d0def75663f2620b6402a017014b57c912dad

M: 614d0def75663f2620b6402a017014b57c912dad192.168.1.171:7001

??slots:66-5460 (5395 slots) master

?? 1additional replica(s)

M: 8aac82b63d42a1989528cd3906579863a5774e77192.168.1.171:7002

??slots:5528-10922 (5395 slots) master

?? 1additional replica(s)

S: adb99506ddccad332e09258565f2e5f4f456a150192.168.1.171:7005

??slots: (0 slots) slave

??replicates 8aac82b63d42a1989528cd3906579863a5774e77

M: 83df08875c7707878756364039df0a4c8658f272192.168.1.171:7003

??slots:10989-16383 (5395 slots) master

?? 1additional replica(s)

[OK] All nodes agree about slotsconfiguration.

>>> Check for open slots...

>>> Check slots coverage...

[OK] All 16384 slots covered.

How many slots do you

want to move (from 1 to 16384)? 199

(注釋:這里不會是正好200個槽)

What is the receiving

node ID? 614d0def75663f2620b6402a017014b57c912dad

(注釋:這里是需要把數(shù)據(jù)移動到哪?7001的主節(jié)點(diǎn)id)

Please enter all thesource node IDs.

? Type 'all' to use all the nodes as sourcenodes for the hash slots.

? Type 'done' once you entered all the sourcenodes IDs.

Source node #1:382634a4025778c040b7213453fd42a709f79e28

(注釋:這里是需要數(shù)據(jù)源决摧,也就是我們的7007節(jié)點(diǎn)id)

Source node #2:done

(注釋:這里直接輸入done 開始生成遷移計劃)

Ready to move 199 slots.

??Source nodes:

??? M: 382634a4025778c040b7213453fd42a709f79e28192.168.1.171:7007

?? slots:0-65,5461-5527,10923-10988 (199 slots)master

?? 0 additional replica(s)

? Destination

node:

??? M: 614d0def75663f2620b6402a017014b57c912dad192.168.1.171:7001

?? slots:66-5460 (5395 slots) master

?? 1 additional replica(s)

?Resharding plan:

Moving slot 0 from 382634a4025778c040b7213453fd42a709f79e28

...

Do you want to

proceed with the proposed reshard plan (yes/no)?Yes

(注釋:這里輸入yes開始遷移)

Moving slot 0 from 192.168.1.171:7007 to192.168.1.171:7001:

...

到此為止我們已經(jīng)成功的把7007主節(jié)點(diǎn)的數(shù)據(jù)遷移到7001上去了亿蒸,我們可以看一下現(xiàn)在的集群狀態(tài)如下圖,你會發(fā)現(xiàn)7007下面已經(jīng)沒有任何數(shù)據(jù)(slot)槽了掌桩,證明遷移成功边锁!


步驟二:最后我們直接使用del-node命令刪除7007主節(jié)點(diǎn)即可(紅色表示7007的節(jié)點(diǎn)id)。

[root@centos 7001]#/usr/local/redis3.0/src/redis-trib.rb del-node

192.168.1.171:7007382634a4025778c040b7213453fd42a709f79e28

輸出如下:

>>> Removing node382634a4025778c040b7213453fd42a709f79e28 from cluster 192.168.1.171:7007

Connecting to node 192.168.1.171:7007: OK

Connecting to node 192.168.1.171:7006: OK

Connecting to node 192.168.1.171:7004: OK

Connecting to node 192.168.1.171:7001: OK

Connecting to node 192.168.1.171:7002: OK

Connecting to node 192.168.1.171:7005: OK

Connecting to node 192.168.1.171:7003: OK

>>> Sending CLUSTER FORGETmessages to the cluster...

>>> SHUTDOWN the node波岛。

最后:我們查看集群狀態(tài)茅坛,一切還原為最初始狀態(tài)啦!OK 結(jié)束!


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末贡蓖,一起剝皮案震驚了整個濱河市曹鸠,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌斥铺,老刑警劉巖彻桃,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異晾蜘,居然都是意外死亡邻眷,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進(jìn)店門剔交,熙熙樓的掌柜王于貴愁眉苦臉地迎上來肆饶,“玉大人,你說我怎么就攤上這事岖常⊙蹦鳎” “怎么了?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵竭鞍,是天一觀的道長阿宅。 經(jīng)常有香客問我,道長笼蛛,這世上最難降的妖魔是什么洒放? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮滨砍,結(jié)果婚禮上往湿,老公的妹妹穿的比我還像新娘。我一直安慰自己惋戏,他們只是感情好领追,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著响逢,像睡著了一般绒窑。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上舔亭,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天些膨,我揣著相機(jī)與錄音,去河邊找鬼钦铺。 笑死订雾,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的矛洞。 我是一名探鬼主播洼哎,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了噩峦?” 一聲冷哼從身側(cè)響起锭沟,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎识补,沒想到半個月后族淮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡李请,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了厉熟。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片导盅。...
    茶點(diǎn)故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖揍瑟,靈堂內(nèi)的尸體忽然破棺而出白翻,到底是詐尸還是另有隱情,我是刑警寧澤绢片,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布滤馍,位于F島的核電站,受9級特大地震影響底循,放射性物質(zhì)發(fā)生泄漏巢株。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一熙涤、第九天 我趴在偏房一處隱蔽的房頂上張望阁苞。 院中可真熱鬧,春花似錦祠挫、人聲如沸那槽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽骚灸。三九已至,卻和暖如春慌植,著一層夾襖步出監(jiān)牢的瞬間甚牲,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工蝶柿, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留鳖藕,地道東北人。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓只锭,卻偏偏與公主長得像著恩,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評論 2 348

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