Linux - CentOS7 - 图片服务器搭建

  • 背景
    Alibaba工程师开源的FastDFS是专门为大流量文件服务的,而一个普通的APP网站并不需要这么大的图片服务,因此这里我们使用VSFTP服务器作为图片服务器,VSFTP理论上能支持4000并发,对于一般的图片服务已经足够。下面我们开始搭建VSFTP图片服务器。

  • Ngnix HTTP服务器搭建

  1. 安装Nginx依赖环境
[root@cat ~]$ yum install -y gcc-c++
[root@cat ~]$ yum install -y pcre pcre-devel
[root@cat ~]$ yum install -y zlib zlib-devel
[root@cat ~]$ yum install -y openssl openssl-devel
  1. 下载Nginx包并将包上传至将要安装Nginx的服务器上

http://nginx.org/download/nginx-1.16.0.tar.gz

  1. 解压Nginx安装包至目标目录
[root@cat soft]$ tar -xvzf nginx-nginx-1.16.0.tar.gz
  1. 进入解压后的文件夹并进行编译安装前的配制
[root@cat soft]$ ll
drwxr-xr-x 8     1001  1001     147 Apr 23 21:13 nginx-1.16.0
-rw-r--r-- 1 mfgitops wheel 1032345 Aug  1 15:12 nginx-1.16.0.tar.gz
[root@cat soft]$ mkdir nginx
[root@cat soft]$ cd nginx-1.16.0
[root@cat nginx-1.16.0]$ ./configure \
> --prefix=/opt/software/nginx \
> --pid-path=/var/run/nginx/nginx.pid \
> --lock-path=/var/lock/nginx.lock \
> --error-log-path=/var/log/nginx/error.log \
> --http-log-path=/var/log/nginx/access.log \
> --with-http_gzip_static_module \
> --http-client-body-temp-path=/var/tmp/nginx/client \
> --http-proxy-temp-path=/var/tmp/nginx/proxy \
> --http-fastcgi-temp-path=/var/tmp/nginx/fastcgi \
> --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \
> --http-scgi-temp-path=/var/tmp/nginx/scgi 
  1. 编译安装
[root@cat nginx-1.16.0]$ make & make install
  1. 启动nginx
    进入刚刚创建的nginx文件夹,查看文件夹内容
[root@cat nginx]$ ll
total 4
drwxr-xr-x 2 root root 4096 Aug  1 15:58 conf
drwxr-xr-x 2 root root   38 Aug  1 15:58 html
drwxr-xr-x 2 root root   18 Aug  1 15:58 sbin

进入sbin目录启动nginx

[root@cat sbin]$  ./nginx
  1. 用浏览器访问nginx
    在浏览器地址栏上输入安装nginx的ip地址即可,我这里是192.168.1.17。结果如下:


    wellcome to nginx

    如果出现欢迎界面,说明nginx安装已经完成。

接下来安装VSFTP服务器
8.安装VSFTP组件

[root@cat sbin]$ yum install -y vsftp
  1. 查看VSFTP启用状态
[root@cat sbin]$ systemctl status vsftpd.service
 Loaded: loaded (/usr/lib/systemd/system/vsftpd.service; disabled; vendor preset: disabled)    
 Active: inactive (dead)

Active为inactive,因此需要手动启动VSFTP服务

[root@cat sbin]$ systemctl start vsftpd.service
● vsftpd.service - Vsftpd ftp daemon
    Loaded: loaded (/usr/lib/systemd/system/vsftpd.service; disabled; vendor preset: disabled)
    Active: active (running) since Thu 2019-08-01 16:17:59 CST; 18s ago
   Process: 28195 ExecStart=/usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf (code=exited, status=0/SUCCESS)
  Main PID: 28198 (vsftpd)
     Tasks: 1
    CGroup: /system.slice/vsftpd.service
            └─28198 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf

Aug 01 16:17:59 SHZLNCOAOP3 systemd[1]: Starting Vsftpd ftp daemon...
Aug 01 16:17:59 SHZLNCOAOP3 systemd[1]: Started Vsftpd ftp daemon.
  1. 设置vsftp用户并设置密码
[root@cat sbin]$ useradd vsftpuser
[root@cat sbin]$ passwd vsftpuser
Changing password for user vsftpuser.
New password:
Retype new password:
passwd: all authentication tokens updated successfully.
  1. 开启上传文件
[root@cat sbin]$ setsebool -P ftpd_full_access on
[root@cat sbin]$ setsebool -P tftp_home_dir on

注意,如果开启过程中出现SELinux is disabled的提示,需要开启SELinux,开启方式如下,将SELINUX设置成1。然后用reboot重启linux即可

[root@cat sbin]$ vim /etc/selinux/config

# This file controls the state of SELinux on the system.
# SELINUX= can take one of these three values:
#     enforcing - SELinux security policy is enforced.
#     permissive - SELinux prints warnings instead of enforcing.
#     disabled - No SELinux policy is loaded.
SELINUX=1
# SELINUXTYPE= can take one of three two values:
#     targeted - Targeted processes are protected,
#     minimum - Modification of targeted policy. Only selected processes are protected.
#     mls - Multi Level Security protection.
SELINUXTYPE=targeted

  1. 配制nginx
    进入我们之前创建的nginx预安装目录,编译nginx.conf文件
[root@cat conf]$ vim nginx.conf

在server里追加以下内配制

location /image {
    root    /data/;
    autoindex on;
}

保存并退出。
这里的配制的意思是,当用户访问ip/image路径时将映射到服务器上的/data/image文件夹上。

  1. 重启nginx
    进入安装目录下的sbin文件夹,执行以下命令
[root@cat sbin]$ ./nginx -s reload

注意,如果重启过程报错:nginx: [emerg] open() "/var/run/nginx/nginx.pid" failed (2: No such file or directory)
执行以下命令即可

mkdir -p /var/run/nginx

再次重启nginx

[root@cat sbin]$ ./nginx -s reload
  • warm tips
    一般修改完nginx配制文件都需要对修改后的配制进行check,check通过再执行重启命令,以提前发现配制异常,减少服务器重启后因异常而不能提供正常服务的风险。check 命令如下
[root@cat sbin]$ ./nginx -t -c nginx.conf文件所在的绝对路径(注意,此处不能用相对路径)
最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容