15分钟从零开始搭建支持10w+用户的生产环境(一)
前言
这是一个基于中小型企业或团队的架构设计。
不考虑大厂。有充分的理由相信,大厂有绝对的实力来搭建一个相当复杂的环境。
中小型企业或团队是个什么样子?
开发团队人员配置不全,部分人员身兼开发过程上下游的数个职责;
没有专职的维护人员,或者维护人员实力不足以完全掌控生产和开发环境。
这种情况下,过于复杂的生产环境设计,规划、安装、调试、修改会牵扯太多的精力。一旦使用过程中出现问题,涉及的技术复杂性会带来不可预估的灾难。
同时,中小型团队的系统,也有其特殊要求,主要表现在:
生产环境的搭建要简单。这个主要是考虑到人员的技术实力。毕竟要求一个开发人员,能熟练安装各种系统的运行环境,是有点太高了;
生产环境的扩展性要足够。因为资金原因,通常前期的服务器资源会比较紧张,而一旦有资金进入,用户量会短时间扩大,服务器资源需求也相应扩大,就需要在不改动代码的情况下,通过简单的操作,把生产环境扩展成较大规模的架构;
需要充分考虑到开发环境与生产环境的衔接。国内大多数开发团队,是采用windows开发,linux布署的模式。这种模式下,开发和生产环境中各个部分的选择尤为重要。最理想的情况,是开发和生产在不同的操作系统下,同环境同代码,避免代码重编译和移植。
本文就是针对这样的要求,进行的设计。
一、服务器的操作系统
Linux。毫无疑问,服务器的操作系统,必须是linux。
很多人选择windows做为服务器操作系统,是因为windows更熟悉,有图形管理界面,比较容易操作。
但实际上,linux做为操作系统的优势更明显:
命令行跟图形界面,仅是输入方式的区别,从功能上没有实质性的区别;命令行更快捷,而且可以形成命令序列,即脚本。
装linux一定不要装GUI,这是一个非常重要的习惯,而且会显得很专业
Linux是开源免费的,或接近免费的,既不存在版权问题,也不存在成本问题。
在相同硬件的情况下,linux更容易获得更高的性能。更容易的意思是,不需要进行太多的配置和调整。在一般使用下,安装完直接使用,性能就很高了。
Linux有很多发行版。通常的选择是Redhat、CentOS、Debian。Redhat是个商业版本,有一定的费用。CentOS、Debian,是免费版本。
中小团队,收费版本就不考虑了。两个免费的版本中,CentOS相对激进点,预装软件会采用比较新的版本,甚至会有测试版本;Debian相对保守,预装的软件都是稳定的版本。另外,CentOS预装的软件比Debian多,所以体积大一些,启动时要加载的东西多一些。
我建议选择用Debian,稳定,占用硬盘小,占用运行内存少。
至于Ubunut、Arch Linux、Mint,学习linux的时候可以好好用,服务器上就算了。如果linux您自己本身不熟悉,就别自找麻烦。
至于linux的内核版本,在购买VPS服务器的时候,镜像都是做好的,没多少可选,用最高版本就好。内核的每个升级,都解决了一些问题,也带来了一些问题。如果不清楚这些问题在哪,或者不知道怎么解决这些问题,就假装不知道。操作系统的问题,包括BUG,包括遗留的内容,我们很难遇到的。
最后多说一句,服务器操作系统一定选择x64的版本,即64位的版本。在服务器上安装应用软件,也要优先选择x64的版本。现在的主流硬件,PC都是x64的,更别说服务器了。
Debian官网:https://www.debian.org
独立的服务器,需要从Debian官网下载ISO进行安装。云服务器,在购买时会先选择安装的镜像。安装的步骤略过,如果需要我可以另开一个贴子写写。
有几个简单的安全方面的内容需要注意:
远程连接服务器时,一定要用ssh。命令是:
ssh username@ipssh username@domain
Windows下没有内建的ssh命令,可以下一个Putty,也要使用ssh模式。
远程登录时,尽量少用root。安装完成后,建一个普通用户,用这个普通用户进行远程登录。进去后,用su升权或用sudo进行操作。
上传文件使用ssh通道。命令是:
scp source_file username@ip:~/target_folder/target_filescp source_file username@domain:~/target_folder/target_file
Windows下可以装一个WinScp来上传文件。
小心使用网上建议的任何方式来改动服务器,除非你知道你在做什么。
在绝大多数情况下,自己开发的应用跑在服务器上时,如果服务器出现了CPU高或内存满的情况,去查代码,而不是怀疑服务器如何如何,也不是去调整服务器的运行参数。
(未完待续)