抛弃 PHP 代价太高,抛弃php代价
抛弃 PHP 代价太高,抛弃php代价
前言
我初次尝试编程使用的语言是php,并且在数个使用php作为主要开发语言的公司工作过。但是,我并不会对其他语言视而不见,并且现如今php已经不是我主要的开发语言了。
我认为我是一个可以因为“不需要过度担心语言设计”与“尽可能轻松地快速地赚钱、完成工作”就会很快乐的人。我最近刚从一个主要以php作为前端开发的全职工作岗位中离职。
最近我通读了那篇虽然已经陈旧但仍勾起如此真实的痛苦,以至于我无法再忽视的博文《Eevee.PHP:糟糕的设计带来的碎片 》。但是,我遇到了一些障碍,这是关于我不使用php后的艰难时期的故事。
做闲时项目的经济问题
我很自由。如果我不想,我可以一行php代码都不用写;我不再需要进行后端开发工作;还有,除非是浏览器由于某些灾难性的变化导致崩溃,否则由于可预见的未来,我将不必去做这些工作。
然而,我确实有一堆我想规划建立并促成实现的项目,项目还不止一个。实际上,我正试着建立一大堆规模略小的网站,以此获得一些满意的消极收入(不缴税收入)。(无论如何这都是我的目标)为此,我昨天启动了我的第一个未命名的网站。
不幸的是,因为这是一个需要自己掏钱的项目以及我很需要建很多站点,我不得不直接割舍一些东西。下面我将罗列它们,解释一下为什么我相信主机提供商不会为我工作,还有谈一下和我处于同一窘境的人们。
Heroku
如果我有钱,我会把所有的应用都放在heroku上面。就我的使用体验而言,Heroku非常不可思议。托管和配置你自己的环境一点儿都不麻烦,与你使用的语言也无关,如此种种。
使用Heroku的问题在于他的收费模式,尽管每个项目每个月7美元看起来并不多,但是当你有许多个项目的时候,费用就像火箭一样蹭蹭蹭往上涨。就算只有十个应用,对于可能没有任何结果的东西而言,每个月上到70美元的成本也已经太高了。
上面的成本甚至都没有考虑使用数据库的因素,每1000万行数据需要额外的9美元。如果一个项目有很大的数据流量,那也会加重应用的成本,很快我们就会发现每个月的成本变成一百多美元。
Amazon web services
AWS 的价格看起来更便宜点,但是我一直认为使用它在许多方面上会增加复杂度,配置和花费上同样会提高成本,对于一个每月只有几百访问量的小网站来说相当不值得。
我不能说我有很多使用AWS的经验,但关于它的一切都有一股浓浓的企业味道,我相信复杂应用的客户才是他们的关注点。
也许怎样有效率地在AWS上部署是值得学习的,但是怎样简单的去部署git服务?为了它我是否需要额外的服务?同样的一个实例是否可以运行多个应用?收费模型又是怎么样的呢?尽管看了他们的价格页面,我还是不明白哪一部分跟我相关。看完他们的网站我心里还是有一堆的问号无法找到答复。
Microsoft Azure
乍一看,微软的Azure似乎才是救世主。然而,即使我非常想要把大型应用部署在这里,我仍然存在一个顾虑,那就是关于Google和HTTPS的。
如果你看一下它们的定价模型,你应该就能明白(图片是从我的主页引用过来的,不好意思上面还带着些瑞典语~),认准这些才是最明智的。如果你选择标准版,据我得到的消息是你可以在上面部署多达50个应用。就我的情况来看,差不多也得选个标准版。每月580克朗,折合美元约70刀。虽然还是贵了点,但在Heroku上面那些我喜欢的特性在这里也都能够提供,这样算来也挺值了。当然,Azure略微复杂了一点,并且价格波动频繁,但瑕不掩瑜。
问题在于定价模型里所描述的标准版只支持5个SNI(Server Name Indication)。这是什么意思?根据我的理解,就是只能有5个站点支持SSL。鉴于Google对于不支持SSL的站点已经越来越不友好了,并且,Let's Encrypt项目已经能让每个网站都可以使用HTTPS加密,在我那多达50个站点中却只有5个能获得SSL支持,这一点实在不太好。以上这些只是我的个人理解,而且它提供的说明也有些少,所以也有可能是我理解错了。事实上,我的确希望是我错了,若果真如此,请大家在文章下面的评论栏里回复我。
GleSYS, Digital Ocean, Linode 自己服务器等
用这些钱去跟上面罗列的这些服务提供商租一个VPS才是唯一实际的替代方案。GleSYS的好处在于,有瑞典主机可用,这意味着低延时,并且数据通过美国政府的审查不存在任何风险。我可以放心地把用户数据存在那里。
相较于托管服务,价格是难以置信地低廉,就是得花点时间配置,你必须自己完成所有的设定和组织,这可是很大的工作量。我之所以选择托管服务,最大的原因就是因为,如果我的某个服务挂掉了,而我正在上班,我就必须等到下班回家以后才能处理这些事情,这都可能是七、八个小时以后的事了。
PHP社区提供解决方案
当Eevee抱怨PHP这个语言缺乏独特的特性的时候,社区已经拿出我试过的最炫的托管解决方案。它也正好是我曾经尝试过的最便宜的。
解决方案是Laravel Forge(Laravel工场).
如果你没有立即访问这个连接,让我给你解释一下。Laravel Forge服务$9一个月,他提供无限制的生产级php服务器(安装,设置和配置),你可以从一个Web界面控制所有的服务。更神奇的是,我可以针对任何VPS提供商,即使是最简单的AWS或数字海洋。这将帮助你扩展服务器,设置cron作业,编辑环境配置,使用git push部署等等。
Laravel Forge服务给我提供了Azure或HeroHu的不限应用数量的良好特性(只要VPS可以处理它)。Laravel Forge是不限于Laravel框架,任何PHP应用程序都行。
像Eevee一样,如果本条不能改进你对PHP社区的观念,没什么能了。但认真说,知道这个的人怎么会离开这么棒的服务呢?
利润是重要的
我认为我的故事是非常常见的。我认为我不是孤单的。世界上肯定有成千上万的小公司的负责人需要托管他们的应用程序。要么他们的项目恰好是一个网站。
一个来自Linode的10美元服务器和9美元的Laravel Forge,他们部署很快很便宜,这样打造的服务器很快就可以替代任何的假设,你就不会想做运维工作,包括服务器启动,运行,安装证书等工作。
我在网络上查找过答案,但是唯一令人信服的替代方案就是使用类似于Codeship的持续集成(Continuous Integration)服务。虽然它不是无限的,而且当你拥有超过5个项目(我有这样的计划)的时候费用直接提高到49美元,但是老实说它的服务确实很不错。另外,Codeship还提供自动化测试以及git推送部署服务,但不提供服务器,所以你仍需要自行准备网站服务器、数据库并配置好。
对于其他语言,也许Laravel Forge有更好的替代方案,也许没有。但我仍然认为,对我以及很多其他人来说,抛弃PHP代价实在太高了。即使我能负担的起,也没有什么意义。
最后,再一次引用Eevee的话:
毋庸置疑,PHP太流行了!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

MySQL适合初学者使用,因为它安装简单、功能强大且易于管理数据。1.安装和配置简单,适用于多种操作系统。2.支持基本操作如创建数据库和表、插入、查询、更新和删除数据。3.提供高级功能如JOIN操作和子查询。4.可以通过索引、查询优化和分表分区来提升性能。5.支持备份、恢复和安全措施,确保数据的安全和一致性。

Navicat本身不存储数据库密码,只能找回加密后的密码。解决办法:1. 检查密码管理器;2. 检查Navicat的“记住密码”功能;3. 重置数据库密码;4. 联系数据库管理员。

使用 Navicat Premium 创建数据库:连接到数据库服务器并输入连接参数。右键单击服务器并选择“创建数据库”。输入新数据库的名称和指定字符集和排序规则。连接到新数据库并在“对象浏览器”中创建表。右键单击表并选择“插入数据”来插入数据。

Navicat for MariaDB 无法直接查看数据库密码,因为密码以加密形式存储。为确保数据库安全,有三个方法可重置密码:通过 Navicat 重置密码,设置复杂密码。查看配置文件(不推荐,风险高)。使用系统命令行工具(不推荐,需要对命令行工具精通)。

可在 Navicat 中通过以下步骤新建 MySQL 连接:打开应用程序并选择“新建连接”(Ctrl N)。选择“MySQL”作为连接类型。输入主机名/IP 地址、端口、用户名和密码。(可选)配置高级选项。保存连接并输入连接名称。

Navicat 无法连接数据库的常见原因及其解决方法:1. 检查服务器运行状态;2. 核对连接信息;3. 调整防火墙设置;4. 配置远程访问;5. 排除网络问题;6. 检查权限;7. 保障版本兼容性;8. 排除其他可能性。

Navicat 连接数据库时常见的错误及解决方案:用户名或密码错误(Error 1045)防火墙阻止连接(Error 2003)连接超时(Error 10060)无法使用套接字连接(Error 1042)SSL 连接错误(Error 10055)连接尝试过多导致主机被阻止(Error 1129)数据库不存在(Error 1049)没有权限连接到数据库(Error 1000)

在 Navicat 中执行 SQL 的步骤:连接到数据库。创建 SQL 编辑器窗口。编写 SQL 查询或脚本。单击“运行”按钮执行查询或脚本。查看结果(如果执行查询的话)。
