StarryDNS 香港VPS 2019 黑色星期五特價!KVM每個月10美金

StarryDNS 香港VPS 2019 黑色星期五特價!KVM每個月10美金

因為網站有連線到中國的需求,但又卡在ICP備案的問題,因此香港的主機往往是連線到中國最佳的機房。
個人使用StarryDNS這家主機商已經兩年多,有許多問題幾乎都在十分鐘內回覆解決。
站長不接業配,也不愛業配,這邊附上我的訂購紀錄跟問答紀錄,可以看到他們都很快地處理。

今天要分享的是,2019 黑色星期五,StarryDNS也很阿莎力給了將近3.5折的特價!!!
雖然我消息晚了,但還是有搶到一台!可選擇香港/荷蘭/新加坡/日本/洛杉磯機房 (發文的當天日本已經賣完了,但日本我推薦Linode的)
下面分享兩款主機規格跟價格。

CPU:1核
內存:1GB
硬碟:50GB / RAID10
流量:500GB / 100Mbps
架構:KVM
IP /面板:1IPv4 / SolusVM
價格:HKD 280/年 ,購買鏈接

CPU:3核
內存:3GB
硬碟:100GB / RAID10
流量:1.2TB / 100Mbps
架構:KVM
IP /面板:1IPv4 / SolusVM
價格:HKD 77/月 ,購買鏈接

重點是,我原本有一台3G-OVZ架構的VPS,明年六月到期,年繳價格是HKD 1133。
我租這台3G-KVM架構的VPS,年繳只要HKD 770!
當然立馬換啦XDD,但原本的還沒到期怎麼辦?又不想同時擁有兩台。
寫信給客服後,他們提供按比例退款,WOW~ 所以我拿回了HKD 591,重新訂購HKD 770一年!

超級划算。

這家真是超級佛心,又很敢給的優質VPS商。五星推薦
黑五特價購買連結點我

香港CN2 VPS 推薦 LOCVPS

香港CN2 VPS 推薦 LOCVPS

之前租用的 星光互聯 香港VPS,
由於已經沒有CN2直連的VPS了,很可惜,只用了一個月就停止了,於是只好再另尋香港VPS 並且有CN2直連的。
我個人對星光互聯的服務很滿意,回覆很快,並且提供的品質也不錯,如果將來他們再次開放CN2的線路,我肯定會再次回流。

接著找到了超爛的pzea vps,官方不只沒有客服聯絡,連我付費了之後也無消無息,最後是費了很多的心力才完成退費。
個人極不推薦pzea vps,用了保證後悔!

最後我找到了loc vps,他們有CN2直連的沙田主機,
客服有在線QQ,回覆時間在1分鐘以內!
並且cn2 對中國及海外的訪客,速度都很棒!
速度很快,並且也不限流量。

loc vps 目前用了快兩個月,感覺品質穩定,速度很快!
個人滿推薦的。

Nginx 透過Proxy_pass php 安裝 WordPress 會遇到的SSL 及 固定網址permalink 問題

Nginx 透過Proxy_pass php 安裝 WordPress 會遇到的SSL 及 固定網址permalink 問題

1.Nginx 安裝Wordpress 會先遇到無窮迴圈問題(too many redirects)
在你的佈景主題中的function.php最下方加入
remove_filter('template_redirect', 'redirect_canonical');

2.遇到SSL進不去的話,wp-config.php最上方(The Top)加入
$_SERVER['HTTP_HOST'] = $_SERVER['HTTP_X_FORWARDED_HOST'];
$_SERVER['HTTPS'] = 'on';

3.固定網址失效(Permalink Don’t work):
修改你的nginx conf,如下
location / {
try_files $uri $uri/ /index.php?q=$uri&$args;
}

同時安裝這個外掛 Permalink Fix & Disable Canonical Redirects Pack

Enjoy!

pzea vps 超爛!沒客服 沒效率

pzea vps 超爛!沒客服 沒效率

兩天前租用了在網上普遍好評的PZEA 香港VPS

結果下定付款後等了兩天,完全無消無息。

寫了三封信給客服,告知我已經購買完畢並且付款,何時可以開通。

48小時過去了,完全沒下文,反倒是收到了一封我發票過期的通知…

完全不知道這是什麼意思?!

看來他行銷做得不錯,網路上一堆水軍,但真正用戶來寫心得的似乎沒有。

建議大家如果有考慮Pzea或是Kvmla的可以直接跳過了,這種服務態度出事了也沒人理。

只能繼續探索尋找新的香港VPS了。

以下是我的購買證明,以及過了兩天,PZEA仍然顯示我未付款(攤手)


香港VPS 推薦 租用心得 沙田主機

香港VPS 推薦 租用心得 沙田主機

這幾天因為需要服務港澳中的網友,所以在網上做了許久的功課,
因為租用香港的主機好處很多,像是連中國速度快又免ICP備案,對國際線路速度也快。
但網路上終究是葉佩文太多,所以做了很久的功課才入手。
最後我選擇的是 星光互聯 – StarryDNS

理由如下:
1.沙田的CN2線路主機對於中國和國際的線路都較快。
2.一開始已經找不到可以購買的介面,寫信給客服反映,處裡的速度很快。
3.至今使用了整整一個月,網站穩定度極高,幾乎達100%
4.價格可以接受。
5.可以用paypal付款 (很重要阿,很多香港主機都只接受支付寶)

其他缺點:
1.第一次購買的客戶需要等待24小時開通,竟然不是全自動…

WordPress MultiUser MultiSite 多用戶部落格使用multi-db 將資料庫分開

WordPress MultiUser MultiSite 多用戶部落格使用multi-db 將資料庫分開

有在使用WordPress MultiSite (WP多用戶站點) 的站長都知道,其資料庫是一個痛!
因為他把用戶的資料表全部塞在同一個資料庫裏面,會造成管理時,光等phpmyadmin列出全部資料表,電腦就當機了!

以我來說,手上有大概一千多位用戶,但資料表加起來竟然有一萬三千八百多個!光是磁碟尋找檔案就耗很多時間了,更別談效率。
wpmulti-db

上圖13858是未使用multi-db之前通通擠在一起的資料表,經過multi-db有系統的規劃後,可以看到下面的列表他拆成256個資料庫,在分門別類把每個資料表移過去。
multi-db允許我們建立16/256/4096個資料庫,用戶建立時資料時會被散列納入相應的資料庫中,這樣就實現了用戶數量級的躍升。

譬如原先我們的是在一個資料庫擠好幾萬個資料表,幾千個用戶,但multi-db之後其承載能力,理論上獲得了×16、×256、×4096的倍率。
當然我們知道其實這不是簡單的乘數效應,因為系統的短板會在不同時期出現在不同的環節,比如blogs.dir的文件數理論極限,比如單一台主機不做負載均衡時單機的負載能力上限,
比如靜態文件請求產生的資源消耗等等。

但是,通過multi-db,我們就可以輕鬆跨越一個資料庫的海量資料表!
此外,對於有特殊需求的用戶,從資料庫穩定性考慮也可以為他們單獨建個別的資料庫。因為不同的資料可以存在於不同的資料庫內,這一切都是可設置的。

不過目前multi-db並非免費,必須至https://premium.wpmudev.org/project/multi-db/ 購買。

以下是安裝心得。

1.不需使用WP普通外掛的方式安裝,他是採檔案上傳後即可運行。
2.先建立你要的資料庫,舉例我這次採用切割成256個資料庫,所以先透過phpmyadmin建好256個資料庫,其建立規則為
CREATE DATABASE `資料庫名稱_00` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
一直到
CREATE DATABASE `資料庫名稱_ff` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
大概會長得像這樣
CREATE DATABASE `wpmudb_ff` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

由於是16進位,所以00(零零)~ff為256,可以自己寫個php 迴圈快速產生指令
for ($i=0;$i<=255;$i++){
echo “CREATE DATABASE `資料庫名稱_”.dechex($i).”` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
“;
}
還要加上主要網誌的資料庫
CREATE DATABASE `資料庫名稱_global` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

※注意,上述語法 0~e 只有一位,前面自行補上0

3.建立好資料庫後,開始要修改檔案了,先產生資料庫的管理權限,一樣產生256個
add_db_server(‘編號’, ‘dc1′, 1, 1,”,’網站IP’, ‘資料庫名稱_編號’, ‘資料庫帳號’, ‘資料庫密碼’);
大概會長得像這樣
add_db_server(’00’, ‘dc1′, 1, 1,”,’111.111.111.111’, ‘wpmudb_00’, ‘admin’, ‘123456’);
別忘了幫主要網誌資料庫也加上密碼
add_db_server(‘global’, ‘dc1′, 1, 1,”,’111.111.111.111’, ‘wpmudb_global’,  ‘admin’, ‘123456’);

將產生出來的add_db_server複製貼上至db-config.php
貼到
//————————————————————————//
//—DB Servers———————————————————–//
//————————————————————————//
// Database servers grouped by dataset.
// R can be 0 (no reads) or a positive integer indicating the order
// in which to attempt communication (all locals, then all remotes)
//
// Usage: add_db_server(DS, DC, READ, WRITE, HOST, LAN_HOST, NAME, USER, PASS)
// EX: add_db_server(‘global’, ‘dc1′, 1, 1,’global.mysql.example.com:3509′,’global.mysql.example.lan:3509’, ‘global-db’, ‘globaluser’, ‘globalpassword’);
//
// Note: you can also place this section in a file called db-list.php in wp-content
// EX: add_db_server(‘global’, ‘dc1′, 1, 1,’global.mysql.example.com:3509′,’global.mysql.example.lan:3509’, ‘global-db’, ‘globaluser’, ‘globalpassword’);
這排下面

————-
4.其他細項修改
//—DB Scaling———————————————————–//
//————————————————————————//
// 16,256,4096
define (‘DB_SCALING’, ‘256’); #因為我用256 所以填256

//————————————————————————//
//—DC IPs—————————————————————//
//————————————————————————//
// Usage: add_dc_ip(IP, DC)
// EX: add_dc_ip(‘123.123.123.’, ‘dc1’);
add_dc_ip(‘111.111.111.111.’, ‘dc1’); #改成網站IP

//————————————————————————//
//—Global Tables——————————————————–//
//————————————————————————//
// Do not include default global tables
// Leave off base prefix (eg: wp_)
// You don’t really have to register these, they will work fine without.
// However registering at least your busiest ones might shave a few milliseconds off by avoiding some regexes.
//
// Usage: add_global_table(TABLE_NAME)
// EX: add_global_table(‘something’);
add_global_table(‘wpmudb_global’); #設定主要網站的資料庫名稱

5.修改move-blogs.php
//————————————————————————//
//—Config—————————————————————//
//————————————————————————//

///DB Settings
$dbname = “原本WP的資料庫名稱”; //This is your current database
$blog_table_prefix = ‘wp_’; //Prefix of your wpmu blog tables, most likely this won’t need to be changed
$newdb_prefix = ‘新的資料庫名稱_’; //本範例應填上 wpmudb

//We need info to connect to the databases
$dbhost = ‘localhost’;
$dbuname = ‘資料庫帳號’;
$dbpass = ‘資料庫密碼’;

//How many db’s are you moving into (16, 256, or 4096)?
$db_scaling = ‘256’; #我建立256個

到這邊就改完了!!

開始準備上傳,
把db.php、db-config.php 上傳至/wp-content/裡面
把move-blogs.php、fix-db-encoding.php 上傳至/wp-content/script/裡面 script資料夾自己建

執行http://網址/wp-content/script/move-blogs.php 會看到下圖,因為我已經完成轉換所以右邊是顯示table in new db
wpmulti-db2

如果設定正確,前面的資料庫也建立正確,此頁面不會出現任何ERROR,如果有ERROR的話 就照他的ERROR去解。
接著按最上面的5.To start the copy process click here 他就會開始跑了!我一萬三千八百多個大概要10分鐘才會結束。

6.最後
做完上述動作,以後系統都會以多資料庫的方式運行,即使增加新用戶也會自動歸類,不需要再做其他設定!非常簡單方便。
——————————————————————————————–

There are using WordPress MultiSite (WP multi-user site) owners are aware that their library is a pain!
Because when he stuffed all the user table in the same database which will cause management, light, etc. phpmyadmin all the information listed in the table, the computer crashed!

I, for one, have got probably more than a thousand users, but add up table yet there are more than thirteen thousand eight hundred! Find files on disk alone consume a lot of time, let alone efficient.

wpmulti-db

The figure 13858 is not used before the multi-db table all crowded together, after a multi-db systematic planning, you can see the list below him split into 256 databases in different categories each table move past.
multi-db allows us to establish 16/256/4096 a database, the user profile will be established when the hash included in the corresponding database, thus achieving the level of the number of users jumped.

For example, originally we are tens of thousands crowded table, thousands of users in a database, but after a multi-db its carrying capacity, theoretically gained × 16, × 256, × 4096 magnification.
Of course, we know that in fact this is not a simple multiplier effect, because the short-board system will appear at different times in different areas, such as the number of files blogs.dir theoretical limit, such as single hosts do load balancing load capacity stand-alone ceiling
For example, the static file requests generated resource consumption and so on.

However, by multi-db, we can easily span a massive database table!
In addition, for users with special needs, from the library to be built in consideration of the stability of individual repository for them separately. Because different materials can exist in different data library, all this can be set.

But the current multi-db is not free, you must purchase to https://premium.wpmudev.org/project/multi-db/.

The following are the installation experience.

1. WP without using ordinary plug mounted, he was taken to run after the file is uploaded.
2. First you have to establish a repository, for example I use this cut 256 database, so the first built 256 database through phpmyadmin, which establish rules
CREATE DATABASE `library name _00` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
until
CREATE DATABASE `library name _ff` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
Probably it would look like this
CREATE DATABASE `wpmudb_ff` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

Because it is hexadecimal, so 00 (2003) ~ ff 256, can write a php loop quickly generate instruction
for ($ i = 0; $ i <= 255; $ i ++) {
echo “CREATE DATABASE` library name _ “dechex ($ i)” `DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci..;
“;
}
Plus major blog repository
CREATE DATABASE `library name _global` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

※ Note that the above grammar 0 ~ e only one, in front of their own make up 0

3. After the establishment of a good database, start to modify the file, the first generation of database administrative privileges, the same generation 256
add_db_server ( ‘No’, ‘dc1’, 1, 1, ”, ‘site IP’, ‘Database name _ Number’, ‘database account’, ‘Database Password’);
Probably it would look like this
add_db_server (’00 ‘,’ dc1 ‘, 1, 1,’ ‘,’ 111.111.111.111 ‘,’ wpmudb_00 ‘,’ admin ‘,’ 123456 ‘);
Do not forget to help the main blog database also add password
add_db_server ( ‘global’, ‘dc1’, 1, 1, ”, ‘111.111.111.111’, ‘wpmudb_global’, ‘admin’, ‘123456’);

Will have to copy and paste out of add_db_server db-config.php
Paste
// ———————————————— ———————— //
// — DB Servers ——————————————- // —————-
// ———————————————— ———————— //
// Database servers grouped by dataset.
// R can be 0 (no reads) or a positive integer indicating the order
// In which to attempt communication (all locals, then all remotes)
//
// Usage: add_db_server (DS, DC, READ, WRITE, HOST, LAN_HOST, NAME, USER, PASS)
// EX: add_db_server ( ‘global’, ‘dc1’, 1, 1, ‘global.mysql.example.com: 3509’, ‘global.mysql.example.lan: 3509’, ‘global-db’, ‘globaluser ‘,’ globalpassword ‘);
//
// Note: you can also place this section in a file called db-list.php in wp-content
// EX: add_db_server ( ‘global’, ‘dc1’, 1, 1, ‘global.mysql.example.com: 3509’, ‘global.mysql.example.lan: 3509’, ‘global-db’, ‘globaluser ‘,’ globalpassword ‘);
This row below

————-
4. Other modifications breakdown
// — DB Scaling ——————————————- // —————-
// ———————————————— ———————— //
// 16,256,4096
define ( ‘DB_SCALING’, ‘256’); # 256 because I used it to fill 256

// ———————————————— ———————— //
// — DC IPs ——————————————- ——————– //
// ———————————————— ———————— //
// Usage: add_dc_ip (IP, DC)
// EX: add_dc_ip ( ‘123.123.123.’, ‘Dc1’);
add_dc_ip ( ‘111.111.111.111.’, ‘dc1’); # change website IP

// ———————————————— ———————— //
// — Global Tables ——————————————- ————- //
// ———————————————— ———————— //
// Do not include default global tables
// Leave off base prefix (eg: wp_)
// You do not really have to register these, they will work fine without.
// However registering at least your busiest ones might shave a few milliseconds off by avoiding some regexes.
//
// Usage: add_global_table (TABLE_NAME)
// EX: add_global_table ( ‘something’);
add_global_table ( ‘wpmudb_global’); # set the main site database name

5. Modify the move-blogs.php
// ———————————————— ———————— //
// — Config ——————————————– ——————- //
// ———————————————— ———————— //

/// DB Settings
$ Dbname = “original WP repository name”; // This is your current database
$ Blog_table_prefix = ‘wp_’; // Prefix of your wpmu blog tables, most likely this will not need to be changed
$ Newdb_prefix = ‘_ new database name’; // This example should fill wpmudb

// We need info to connect to the databases
$ Dbhost = ‘localhost’;
$ Dbuname = ‘database account’;
$ Dbpass = ‘Database Password’;

// How many db’s are you moving into (16, 256, or 4096)?
$ Db_scaling = ‘256’; # I created 256

To change over to the side !!

Begin uploading,
The db.php, db-config.php uploaded to / wp-content / inside
The move-blogs.php, fix-db-encoding.php uploaded to / wp-content / script / folder inside the script to build their own

Executive http: // URL /wp-content/script/move-blogs.php will see the following figure, because I have done so on the right is a graph showing the conversion table in new db

wpmulti-db2

If set up properly, the front of the library also established correctly, this page will not be any ERROR, if ERROR, then did as he had gone to ERROR.
Followed by the top 5.To start the copy process click here he’ll start running! I was more than thirteen thousand eight hundred take about 10 minutes before the end.

6. Finally
To complete the operation, after the system will be in multi-mode operation of the database, even if the increase in new users will automatically categorize not need to do other settings! Very simple and convenient.

網站管理員的基本素養(二) 什麼是架站?

網站管理員的基本素養(二) 什麼是架站?

2xadcv
(我好想好想趕快學會阿~!!!)

這段要先感謝我哥,因為我們常常在遛狗的時候,我會跟他解釋網站架站的一些概念。
哥哥是我的忠實聽眾,而且他完全不是相關科系,
所以如果能讓他徹底明白的話,我會很有成就感,
我試著把跟哥哥說的話打成文章,跟大家分享。

「什麼是架站?」
常常聽到有人會問我,「ㄟ~Yan 你會不會架站」或是「欸~ Yan 你能不能幫我架個網站」
就我自己的觀念「架站」偏向硬體,就是搞一台Server出來。「架網站」則偏向軟體,也就是寫出一個網站。
台灣針對架站的資訊很豐富,隨便Google都有一堆教學文章,所以我比較想講的是概念性的東西。

Read More Read More

網站管理員的基本素養(一)

網站管理員的基本素養(一)


自序:
從2001到2014
由虛擬主機到VPS
從DIY電腦到Dell Server
由台灣到全球

我是Yan, 2001年起,使用IIS的虛擬空間開始架站,一直到現在2014進入機房,在架網站這條路上經歷了約13年,
走過很多冤枉路,也吃過很多虧.目前我手上還在運作的網站約有六個,台灣四個站,中國兩個站.
本人也持續在研究架站的相關技術,
許多資料都是在網路上查到的,因此今天也想把自己所了解的分享出來,
希望能幫助到想架站或是想了解什麼是架站的網友.

Read More Read More

MySQL 複製資料到另一個資料表

MySQL 複製資料到另一個資料表

要把兩個資料表合併成一個很簡單。
INSERT INTO table1 (item1, item2, item3...) SELECT item1, item2, item3... FROM table2
這是把table2的東西塞到table1的狀況,後面也可以用WHERE去做一個資料篩選的動作。

or

CREATE TABLE new_table LIKE my_db.old_table;
然後複製
INSERT new_table SELECT * FROM my_db.old_table;

Amazon 在台灣設立 AWS 新節點

Amazon 在台灣設立 AWS 新節點

我們很高興向各位宣佈,為了服務 Amazon CloudFront和Amazon Route 53 的终端用户,
AWS在台北和巴西里約熱內盧推出新的節點。這是我們首次在台灣設立的第一個節點,里
約熱內盧則是繼聖保羅市之後,巴西的第二個節點。這兩個地點讓全世界的AWS節點總數
高達 51 個。

若您已經是Amazon CloudFront或Amazon Route 53的用戶,您的應用程式不需要做任何的
變更就可以享用這些新的節點服務。來自這些地區终端用户的請求,將會自動被導引而獲
得最佳的性能。

台北和里約熱內盧的新節點支援所有CloudFront與Route 53的功能,其中包括讓您的整個
網站能夠加速(靜態、動態和互動式內容)、直播和隨選串流媒體,提供使用者自訂SSL
認證、私有內容和地理限制等資安保障。

台北新節點的價格與香港、韓國和新加坡是相同的,而里約熱內盧新節點價格則與南美洲
相同。亦即表示著您在這些地區的终端用户將享受更低的延遲時間,而無需支付任何額外
的費用。
————————————————————————————————————
什麼時候Linode也來台灣設節點阿?!