手头有几个尚未开发的域名,反正用的是AWS,就想着为每个域名创建一个简单站点。思路很简单,先做好了一个模板站点,然后拷贝,修改相应的东西(如url,用户名)。
手头有几个尚未开发的域名,如下:
预期能为这些域名找个做出国服务(如旅游、出国留学、移民)的好婆家,但在找到好归属之前,先为他们分别做一个站点。我博客用的主机是AWS,也不需要加大投入,加上对wordpress建站也比较熟,就想着为以上域名分别做一个站点,鉴于内容类似,很自然就想着,如何能批量做几个wordpress站点。
思路倒是很简单:先建好一个模板站点(比如主题、导航条、插件、投放广告),复制该站点,做一些必要的修改(主要是url),就可以得到一个新的站点。
我前前后后使用主机有:香港主机91(巨坑)、新浪云主机(世界上没有免费的午餐)、亚马逊云主机AWS(有些钱还是可以发的)。之前整理的笔记如下:
(1)亚马逊AWS
(2)新浪云
需要修改的地方如下,其中绿色标注的(site icon和header image手动修改):
(1)复制数据库
复制数据库,我直接在phpmyadmin上面完成的,具体操作方法如下:
select database (e.g., to49) –> Operations –> Copy database to: –> type new database name (e.g., to47) –> click Go
(2)修改数据库内容
如3.1所述,需要修改url、博客名称、博客描述、用户名、分类名称,SQL源代码如下(最主要是要找到需要修改的内容都在哪些表里):
SET @old_url='to49.com'; SET @new_url='to47.com'; -- ------- change urls ------------ UPDATE wp_options SET option_value = replace(option_value, @old_url, @new_url) WHERE option_name = 'home' OR option_name = 'siteurl'; UPDATE wp_posts SET guid = replace(guid, @old_url, @new_url); -- UPDATE wp_posts SET post_content = replace(post_content, @old_url, @new_url); UPDATE wp_postmeta SET meta_value = replace(meta_value, @old_url, @new_url); -- -------- change user name --------- SET @old_user='to49'; SET @new_user='to47'; UPDATE wp_users SET user_login = replace(user_login, @old_user, @new_user); UPDATE wp_users SET user_nicename = replace(user_nicename, @old_user, @new_user); UPDATE wp_users SET display_name = replace(display_name, @old_user, @new_user); UPDATE wp_usermeta SET meta_value = replace(meta_value, @old_user, @new_user); -- ----------- change country --------------- SET @old_country='Germany'; SET @new_country='Norway'; -- change blog name and blog description UPDATE wp_options SET option_value = replace(option_value, @old_Country, @new_Country) WHERE option_name = 'blogname' OR option_name = 'blogdescription'; SET @old_country_code='49'; SET @new_country_code='47'; UPDATE wp_options SET option_value = replace(option_value, @old_country_code, @new_country_code) WHERE option_name = 'blogdescription'; -- change category name UPDATE wp_terms SET name = replace(name, @old_country, @new_country); UPDATE wp_terms SET slug = replace(slug, LOWER(@old_country), LOWER(@new_country)); -- germany --> norway
通过以下命令复制模板站点的源码,并修改wp-config.php的数据库名称(如to49 –> to47):
/var/www/$ cp -R to49.com to47.com
值得注意的是,复制过后需要修改文件的权限,否则无法安装主题和插件,详情参考博文《将AWS EC2中网页服务器目录/var/www/的权限设到最优》,主要命令如下(以to47为例):
sudo chown -R ubuntu:www-pub /var/www/to47.com find /var/www/to47.com -type d -exec chmod 2775 {} + find /var/www/to47.com -type f -exec chmod 0664 {} +
打开/etc/hosts文件,在文件末尾将上述域名添加进去:
#added by sparkandshine #xx.xx.xx.xx为AWS EC2 Elastic IP xx.xx.xx.xx to49.com xx.xx.xx.xx to47.com
在/etc/apache2/site-available/目录下创建apache配置文件(可以将其放在一个文件,如others.conf),内容如下:
<VirtualHost *:80> DocumentRoot /var/www/to49.com Servername to49.com ServerAlias www.to49.com </VirtualHost> <VirtualHost *:80> DocumentRoot /var/www/to31.com Servername to31.com ServerAlias www.to31.com </VirtualHost> <VirtualHost *:80> DocumentRoot /var/www/to47.com Servername to47.com ServerAlias www.to47.com </VirtualHost> <VirtualHost *:80> DocumentRoot /var/www/to52.com Servername to52.com ServerAlias www.to52.com </VirtualHost> <VirtualHost *:80> DocumentRoot /var/www/to65.com Servername to65.com ServerAlias www.to65.com </VirtualHost> <VirtualHost *:80> DocumentRoot /var/www/to63.com Servername to63.com ServerAlias www.to63.com </VirtualHost>
启用配置文件,重新加载apache配置文件,命令如下:
sudo a2ensite others.conf sudo /etc/init.d/apache2 reload
完成了上述的步骤,所以站点都能正常访问了,登录Dashboard,手动修改site icon和header image.
实际上,上述所有步骤可以写个脚本自动完成。但鉴于批量建的站不多,有些工作手工做了。