1.购买阿里云服务器
1.配置
1.进入阿里云控制台
2.修改管理密码
修改管理密码
3.配置入口出口安全组
a.入口安全组,用于访问服务器
入口安全组
配置之后,可通过外部访问该服务器(上图配置为ssh协议)
ssh root@00.00.00.00 // IP是服务器公网IP
然后输入密码,密码为第二步中的修改密码
2.域名
1.域名购买
2.域名解析
3.备案
3.部署环境配置(安装各种开发环境,node、python等)
1.安装node
cd .. //到根目录下
mkdir software // 创建文件夹,存放下载的文件
cd software
// 用wget下载node资源文件,版本号可自己定
wget https://nodejs.org/dist/v10.16.0/node-v10.16.0-linux-x64.tar.xz
tar xvf node-v10.16.0-linux-x64.tar.xz // 解压文件
ln -s /software/node-v10.16.0-linux-x64/bin/node /usr/local/bin/node // 创建软连接
ln -s /software/node-v10.16.0-linux-x64/bin/npm /usr/local/bin/npm // 创建软连接
2.安装python
// 安装python依赖环境
yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gcc make
// 安装pip需要的依赖环境
yum install libffi-devel -y
// 下载安装包
wget https://www.python.org/ftp/python/3.7.4/Python-3.7.4.tgz
// 解压安装包
tar -zxvf Python-3.7.4.tgz
// 到文件夹下
cd Python-Python-3.7.4
// 当前文件
./configure
// 编译并安装
make&&make install
到这里基本安装完成了
python3.7安装在/usr/local/bin/下面,一般阿里云机器会预装Python2.7,此时默认命令python
启动的是2.7版本,可以将python指令指向3.7版本
// 修改指令指向
mv /usr/bin/python /usr/bin/python.bak
ln -s /usr/local/bin/python3 /usr/bin/python
// 修改pip指令指向
mv /usr/bin/pip /usr/bin/pip.bak
ln -s /usr/local/bin/pip3 /usr/bin/pip
将python指令指向3.7版本后,有些默认的软件可能需要修改,例如yum只支持2.7,不支持3.7,要修改相关文件,文件位置
/usr/libexec/urlgrabber-ext-down
/usr/bin/yum
用编辑器,将上述两个文件中的
#!/usr/bin/python
修改为
#!/usr/bin/python2.7
保存即可
3.安装mongo
// 下载安装包
wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-4.0.10.tgz
// 解压
tar -zxvf mongodb-linux-x86_64-4.0.10.tgz
// 将解压包移动到指定目录下
mv mongodb-linux-x86_64-4.0.10 /usr/local/mongodb
// 创建数据存放目录
mkdir -p data/db
// 创建日志目录
mkdir -p data/logs
// 创建配置文件
vi mongodb.conf
配置文件用于启动数据库时使用,配置文件内容
#数据位置
dbpath = /usr/local/mongodb/bin/data/db
#日志位置
logpath = /usr/local/mongodb/bin/data/logs/mongodb.log
#端口号
port = 27017
#以守护程序的方式启用,即在后台运行
fork = true
配置好配置文件后用文件启动数据库
//启动数据库
./mongod -f ./mongodb.conf
// 关闭数据库
./mongod -f ./mongodb.conf --shutdown
注意到上面的操作都是在bin目录下,这样操作很麻烦,可以将mongo的命令添加到环境变量中,这样在任何地方都能执行操作
// 用编辑器修改系统的profile文件
vi /etc/profile
增加内容
export MONGODB_HOME=/usr/local/mongodb
export PATH=$PATH:$MONGODB_HOME/bin
保存后执行该文件
source /etc/profile
这样在任何地方都能使用相关命令了
4.PM2(node进程管理)
// 直接用npm安装
npm install -g pm2
// 创建软连接
ln -s /software/node-v10.16.0-linux-x64/bin/pm2 /usr/local/bin/pm2
ln -s /software/node-v10.16.0-linux-x64/bin/pm2-dev /usr/local/bin/pm2-dev
ln -s /software/node-v10.16.0-linux-x64/bin/pm2-runtime /usr/local/bin/pm2-runtime
ln -s /software/node-v10.16.0-linux-x64/bin/pm2-docker /usr/local/bin/pm2-docker
4.拉取代码,部署
1.安装git
yum install git
2.获取前后端代码
git clone ......
3.pm2启动后端服务nodejs
一般node程序都是从www文件启动,找到文件,直接启动
pm2 start /software/DogBrain/bin/www
4.pm2启动前端vue项目
pm2是管理node进程的工具,可以将vue项目打包,然后用express启动一个服务,间接启动vue项目
vue项目打包
npm run build
打包后会出现一个dist文件夹,里面有两个文件index.html和static文件夹
将文件放到服务器上
创建一个DogBrainFount.js文件,文件内容
const fs = require('fs');
const path = require('path');
const express = require('express');
const app = express();
//vue目录,注意dist文件的路径
app.use(express.static(path.resolve(__dirname, './dist')))
//
app.get('*', function(req, res) {
const html = fs.readFileSync(path.resolve(__dirname, './dist/index.html'), 'utf-8')
res.send(html)
})
//定义启动的端口号
app.listen(8080);
用pm2启动这个文件即可将vue项目启动
pm2 start DogBrainFount.js
5.爬虫项目部署
网站首页的数据来自知乎日报、爱范儿等网站
用scrapy框架爬取数据
将scrapy项目代码放的服务器上
安装crontabs定时执行脚本,每天定时爬取网站内容
// 安装crontabs
yum install crontabs
// 创建脚本文件
touch rmtmp.sh
// 编辑脚本文件
vim rmtmp.sh
脚本内容
#!bin/bash
#到执行文件路径下
cd /software/DogBrainSpider/
#执行命令
scrapy crawl zhihuDaily
接下来
// 文件授权
chmod 777 rmtmp.sh
// 设置定时任务
crontab -e
设置任务内容
// 每天上午9:10分执行脚本,爬取数据
10 9 * * * /home/DogBrain/rmtmp.sh
接下来
// 重新加载
systemctl reload crond
// 重新启动
systemctl restart crond
查看已配置任务
crontab -l
定时用的corn语法,详细可以看这篇文章corn语法
网友评论