基于ECS搭建的应用示例(博客、密码管理、同学地图、APP服务端等)详解之一

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: 作为互联网行业从业者,头脑里总是会冒出各种各样的想法,当然可以用网络笔记、云盘甚至本地的方式等记录下自己的想法,然而如果想要落地尝试,则拥有一台自己的服务器就再好不过了。全栈开发已经讲了很久了,如果是前端,通过nodejs也可以搭建后端服务;如果是后端,通过flutter、uniapp等也可以搭建出各种端上的APP;如果非研发人员,通过低代码开发平台拖拽也可以。有了自己的产品之后,如果不满足于本地跑跑,那么就得面临选择应用的载体了,性价比最高的方式是选择云上ECS,下面拿我的几年使用经验来展开讲一下。

起源

ECS可供选择的云厂商比较多,我个人使用过linode、腾讯云、阿里云等几家的ECS产品,其中linode是接触最早的,大概用了两三年时间,每个月10个美元,当时出于接入点距离考虑选择了位于东京机房的服务器,但即便这样,打开博客经常性明显感觉到慢,有时甚至通过终端连接到服务器都超时。后来实在是忍受不了了,就切到了国内的云厂商,选择一个和自己同城的机房,毕竟做出的产品要先取悦自己嘛,结果证明是真香。国内的对比下来,阿里云整体是功能最完善丰富、技术最强大的了。选用一个标准的2C4G配置,使用到至今近三年时间。

image.png


我都拿ECS做了什么

我个人的刚需是博客记录、密码管理,再有就是日常脑海里浮现的想法的落地。当前实现了个人博客以及写作能力的搭建,密码管理的搭建,同学信息地图web应用的搭建,砍一刀、投票、抢票等助力APP的搭建等。


个人博客

image.png


密码管理

image.png

同学信息地图

蓝男橙女,点开可以展示对应同学资料信息,发到微信同学群里还挺受大家喜欢,短时间内就有几十名同学录入进来。

image.png

image.png

助力APP

这个比较复杂,从规划设计到开发落地,走了多处死胡同,作为个人开发者发布小程序或者应用太难了。

也提前了解过flutter,并基于flutter开了个简单的小样,但这里我最终还是选择使用了uniapp进行开发,主要是看到了社区里有较为丰富的插件,也支持我想要部署的小程序和端。

这块涉及端上的开发和后端开发,耗时3个月终于开发完毕,不过当前只支持Android系统。里面的细节这里先卖个关子,后面有机会再做展开。


举个栗子

服务器概览

image.png

根据控制台指引,安装CPU和内存使用率对应的插件,可以直接查看当前的系统负载情况。

image.png


有了服务器后,这里找一个大家都会用到的博客作为示例来展开讲一下吧。


博客技术组成拆解

这里我不使用saas化的博客产品,因为saas化的产品留给自己施展的空间有限,而是自己来搭建。那这里就涉及以下几个方面:

  • 编辑器                 ——markdown
  • 存储设计              ——MySQL
  • 定时任务渲染页面    ——crontab
  • web服务器            ——Nginx
  • 评论                    ——fastcgi


第一步 确定编辑器

选择博客的编辑器,自己实现成本会比较高,因为涉及到富文本编辑器的功能,这里我主要对比了两款,editor和markdown


https://github.com/kindsoft/kindeditor

image.png


https://github.com/pandao/editor.md

image.png


这里我两个都根据官方指引搭建了下,各有利弊,markdown整体体验下来好一些,用的多一些。


这里也需要借助web服务器才可以完整使用,到第四步一起说。


第二步 搭建MySQL

由于个人博客,大多数场景是自己记录查看使用,很少有爆火产生非常大流量的情况。因此这里也没必要单独采购MySQL做分离,完全可以都集成到同一台ECS上。


sudo yum install -y mysql mysql-server mysql-devel
# 修改端口啥的配置sudovim /etc/my.cnf
# 启动MySQLsudoservice mysqld startmysql -hlocalhost-uroot-p


这里注意下,最好设置成仅本机localhost可以登录,避免不必要的安全麻烦。


mysql> show tables;
+--------------------------+| Tables_in_Blog           |
+--------------------------+| t_blog                   |
| t_comments               |
| t_type_def               |
+--------------------------+3 rows inset (0.00 sec)

库表比较简单,共分为博客内容表、评论表、以及博客内容分类表。比较复杂的博客表建表语句如下:

| t_blog | CREATE TABLE `t_blog` (
`c_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`c_title` varchar(255) NOT NULL,
`c_tag` varchar(45) DEFAULT NULL,
`c_date` date NOT NULL,
`c_content` text NOT NULL,
`c_url` varchar(255) NOT NULL,
`c_type` tinyint(4) NOT NULL DEFAULT '1',
`c_keys` varchar(255) NOT NULL,
`c_bid` char(6) NOT NULL,
`c_mtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`c_state` tinyint(4) NOT NULL DEFAULT '0',
`c_nums` bigint(20) DEFAULT '1',
  PRIMARY KEY (`c_id`) USING BTREE,
  UNIQUE KEY `Index_uniq` (`c_bid`),
  KEY `Index_date` (`c_date`),
  KEY `Index_type` (`c_type`),
  KEY `Index_title` (`c_title`)
) ENGINE=InnoDB AUTO_INCREMENT=3682 DEFAULT CHARSET=utf8 |


第三步 定时任务渲染页面

由于是单机,这里利用Linux自带的crontab服务即可。

*/1 * * * * cd /**/**/**/blog;./markdownToHtml.sh >> /**/**/blog_markdownToHtml.log 2>&1

这里是每隔1分钟将编辑器里新增构建保存到数据库里初始状态的内容,转换为自己喜欢的博客html格式,并加上页头和页尾。


第四步 搭建web服务器

这里我选择使用比较常用的Nginx服务器,并使用fastcgi的能力,集成CGI接口提供评论的能力。另外,第二步当中使用到的编辑器里关于图片上传等相关的能力使用了PHP,这里要使得Nginx支持PHP。


  • 安装运行Nginx
sudo yum install nginx
# 切换到root 启动Nginxsystemctl start nginx
# 查看Nginx的运行状态systemctl status nginx
● nginx.service - SYSV: Nginx is a high-performance web and proxy server.
   Loaded: loaded (/etc/rc.d/init.d/nginx; bad; vendor preset: disabled)
   Active: active (running) since 五 2021-04-1622:10:39 CST; 1 years 0 months ago
     Docs: man:systemd-sysv-generator(8)
 Main PID: 21312 (nginx)
   CGroup: /system.slice/nginx.service
           ├─25914 nginx: master process /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
           └─25915 nginx: worker process
  • 配置Nginx 支持fastcgi
location ~ /blog.cgi
  {
    root    /**/**/**/cgi-bin/;
    fastcgi_pass 127.0.0.1:9911;
    fastcgi_index index.cgi;
    fastcgi_param SCRIPT_FILENAME fcgi$fastcgi_script_name;
    include        fastcgi_params;
  }
  • 配置Nginx 支持PHP

1. php包下载

https://secure.php.net/downloads.php

https://secure.php.net/get/php-7.1.7.tar.gz/from/a/mirror

2. 解压安装包后执行

./configure
--prefix=/data/php  --enable-fpm--enable-mbstring--disable-pdo--with-curl--disable-debug--disable-rpath--enable-inline-optimization--with-bz2--with-zlib--enable-sockets--enable-sysvsem--enable-sysvshm--enable-pcntl--enable-mbregex--with-mhash--enable-zip--with-pcre-regex--with-jpeg-dir# 若碰到如下报错:configure: error: xml2-config
not found. Please check your libxml2 installation.
# 意味着缺少xml2相关库,执行下述命令解决sudo yum install libxml2-devel -ychecking for cURL in default path... not found
configure: error: Please reinstall the libcurl
distribution
# 缺少curl相关库sudo yum -y install curl-devel


  1. 安装和启动
make & make test & sudomake install
# 启动php-fpm/data/php/sbin/php-fpm
提示
PHP error:ERROR: No pool
defined. at least one pool section must be specified in config file
配置文件目录中没有.conf结尾的文件
cd /data/php/etc/php-fpm.d/; cp www.conf.default www.conf


  1. 调整Nginx配置并重启


第五步 写fastcgi接口

这里选择c语言的clearsilver包来写fastcgi,纯属是带有个人纪念意义色彩的举动。

不过不管怎样,提供的http接口能力是一致的,即:

  1. 接收评论相关的入参:文章id、评论内容、提交者信息;
  2. 进行入参合法性校验;
  3. 维护到DB里
  4. 在文章加载时提供根据文章ID分页查询评论的能力。


逻辑相对简单,这里就不展开了。


总结

以上只是列举了使用ECS落地个人想法的一个案例,还有像其他的跑一下Python脚本处理个文件数据、写个爬虫程序获取自己感兴趣的内容、验证个技术想法等等还是很方便的,作为技术人员尤其是后端,非常建议入手一台,搭建自己的练兵场。

相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
20天前
|
弹性计算 运维 安全
云服务器 ECS产品使用问题之怎么添加登录密码
云服务器ECS(Elastic Compute Service)是各大云服务商阿里云提供的一种基础云计算服务,它允许用户租用云端计算资源来部署和运行各种应用程序。以下是一个关于如何使用ECS产品的综合指南。
云服务器 ECS产品使用问题之怎么添加登录密码
|
8天前
|
缓存 数据安全/隐私保护 UED
代理服务器在HTTP请求中的应用:Ruby实例
代理服务器在HTTP请求中的应用:Ruby实例
|
16天前
|
监控 物联网 数据挖掘
PHP不仅在Web开发领域有着广泛的应用,其在服务器端的应用也非常重要
【8月更文挑战第4天】PHP不仅在Web开发领域有着广泛的应用,其在服务器端的应用也非常重要
32 8
|
16天前
|
运维 应用服务中间件 持续交付
自动化运维之宝:Ansible在服务器管理中的应用
【8月更文挑战第4天】本文深入探讨了Ansible这一自动化运维工具的实际应用,通过具体案例展示了其在服务器配置、软件部署和系统管理中的强大功能。文章不仅介绍了Ansible的基本操作,还提供了代码示例和实践技巧,旨在帮助读者有效提升运维效率。
41 6
|
16天前
|
存储 人工智能 运维
裸金属服务器详解:定义、核心特点与应用
裸金属服务器,又称单租户环境物理服务器,是指由一个或多个独立的服务器组成,提供专属的物理计算资源。它是服务器领域的一个创新产物,结合了虚拟机的弹性和物理机的性能优势,成为云端的一个专用物理服务器。裸金属服务器在硬件层面直接提供计算资源,不经过虚拟化层,从而避免了虚拟化带来的性能损耗,为用户提供了极致的计算性能和资源独占性。
|
20天前
|
弹性计算 Linux 数据安全/隐私保护
云服务器 ECS产品使用问题之linux如何设置服务器密码
云服务器ECS(Elastic Compute Service)是各大云服务商阿里云提供的一种基础云计算服务,它允许用户租用云端计算资源来部署和运行各种应用程序。以下是一个关于如何使用ECS产品的综合指南。
|
23天前
|
存储 人工智能 数据可视化
阿里云服务器的十二种典型应用场景
阿里云还提供了数据可视化服务DataV,帮助用户通过图形化的界面轻松搭建专业水准的可视化应用。用户可以利用DataV进行数据监控、调度和会展演示等工作,提高数据分析和决策的效率。
|
24天前
|
关系型数据库 Java 分布式数据库
PolarDB产品使用问题之部署到服务器上的Java应用(以jar包形式运行)无法连接,如何解决
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
1月前
|
JavaScript 前端开发 搜索推荐
服务器端渲染技术SSR与ISR:深入解析与应用
【7月更文挑战第20天】服务器端渲染(SSR)和增量静态再生(ISR)作为现代Web开发中的两种重要渲染技术,各有其独特的优势和适用场景。在实际应用中,开发者应根据具体需求和条件选择合适的渲染模式。无论是追求极致的页面加载速度和SEO优化,还是实现内容的实时更新,SSR和ISR都能提供有效的解决方案。通过深入理解这些技术的工作原理和应用场景,开发者可以构建出更加高效、可靠和用户体验优异的Web应用。
|
1月前
|
安全 前端开发 网络安全
【Azure App Service】访问App Service应用报错 SSL: WRONG_VERSION_NUMBER(上海蓝云阻断页)
在Azure App Service上部署的应用遇到`SSL: WRONG_VERSION_NUMBER`错误。问题可能由不兼容的TLS版本引起,但即使将最小入站TLS版本改为1.2,问题仍存在。实际原因是上海蓝云的阻断页面,表明网站未完成ICP备案或有安全规定限制。解决方案包括:1) 对App Service绑定自定义域名并进行ICP备案,或2) 使用Application Gateway处理公网请求。在复杂环境中,需仔细排查和适配规则。
88 11