Maison développement back-end tutoriel php 抛弃 PHP 代价太高_php文摘

抛弃 PHP 代价太高_php文摘

May 16, 2016 pm 07:53 PM
mysql 服务器

前言

我初次尝试编程使用的语言是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太流行了!
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Compétences de traitement de structures de données volumineuses de PHP Compétences de traitement de structures de données volumineuses de PHP May 08, 2024 am 10:24 AM

Compétences en matière de traitement de la structure des Big Data : Chunking : décomposez l'ensemble de données et traitez-le en morceaux pour réduire la consommation de mémoire. Générateur : générez des éléments de données un par un sans charger l'intégralité de l'ensemble de données, adapté à des ensembles de données illimités. Streaming : lisez des fichiers ou interrogez les résultats ligne par ligne, adapté aux fichiers volumineux ou aux données distantes. Stockage externe : pour les ensembles de données très volumineux, stockez les données dans une base de données ou NoSQL.

Comment optimiser les performances des requêtes MySQL en PHP ? Comment optimiser les performances des requêtes MySQL en PHP ? Jun 03, 2024 pm 08:11 PM

Les performances des requêtes MySQL peuvent être optimisées en créant des index qui réduisent le temps de recherche d'une complexité linéaire à une complexité logarithmique. Utilisez PreparedStatements pour empêcher l’injection SQL et améliorer les performances des requêtes. Limitez les résultats des requêtes et réduisez la quantité de données traitées par le serveur. Optimisez les requêtes de jointure, notamment en utilisant des types de jointure appropriés, en créant des index et en envisageant l'utilisation de sous-requêtes. Analyser les requêtes pour identifier les goulots d'étranglement ; utiliser la mise en cache pour réduire la charge de la base de données ; optimiser le code PHP afin de minimiser les frais généraux.

Comment utiliser la sauvegarde et la restauration MySQL en PHP ? Comment utiliser la sauvegarde et la restauration MySQL en PHP ? Jun 03, 2024 pm 12:19 PM

La sauvegarde et la restauration d'une base de données MySQL en PHP peuvent être réalisées en suivant ces étapes : Sauvegarder la base de données : Utilisez la commande mysqldump pour vider la base de données dans un fichier SQL. Restaurer la base de données : utilisez la commande mysql pour restaurer la base de données à partir de fichiers SQL.

Comment insérer des données dans une table MySQL en utilisant PHP ? Comment insérer des données dans une table MySQL en utilisant PHP ? Jun 02, 2024 pm 02:26 PM

Comment insérer des données dans une table MySQL ? Connectez-vous à la base de données : utilisez mysqli pour établir une connexion à la base de données. Préparez la requête SQL : Écrivez une instruction INSERT pour spécifier les colonnes et les valeurs à insérer. Exécuter la requête : utilisez la méthode query() pour exécuter la requête d'insertion en cas de succès, un message de confirmation sera généré.

Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Dec 09, 2024 am 11:42 AM

L'un des changements majeurs introduits dans MySQL 8.4 (la dernière version LTS en 2024) est que le plugin « MySQL Native Password » n'est plus activé par défaut. De plus, MySQL 9.0 supprime complètement ce plugin. Ce changement affecte PHP et d'autres applications

Comment utiliser les procédures stockées MySQL en PHP ? Comment utiliser les procédures stockées MySQL en PHP ? Jun 02, 2024 pm 02:13 PM

Pour utiliser les procédures stockées MySQL en PHP : Utilisez PDO ou l'extension MySQLi pour vous connecter à une base de données MySQL. Préparez l'instruction pour appeler la procédure stockée. Exécutez la procédure stockée. Traitez le jeu de résultats (si la procédure stockée renvoie des résultats). Fermez la connexion à la base de données.

Comment créer une table MySQL en utilisant PHP ? Comment créer une table MySQL en utilisant PHP ? Jun 04, 2024 pm 01:57 PM

La création d'une table MySQL à l'aide de PHP nécessite les étapes suivantes : Connectez-vous à la base de données. Créez la base de données si elle n'existe pas. Sélectionnez une base de données. Créer un tableau. Exécutez la requête. Fermez la connexion.

La différence entre la base de données Oracle et MySQL La différence entre la base de données Oracle et MySQL May 10, 2024 am 01:54 AM

La base de données Oracle et MySQL sont toutes deux des bases de données basées sur le modèle relationnel, mais Oracle est supérieur en termes de compatibilité, d'évolutivité, de types de données et de sécurité ; tandis que MySQL se concentre sur la vitesse et la flexibilité et est plus adapté aux ensembles de données de petite et moyenne taille. ① Oracle propose une large gamme de types de données, ② fournit des fonctionnalités de sécurité avancées, ③ convient aux applications de niveau entreprise ; ① MySQL prend en charge les types de données NoSQL, ② a moins de mesures de sécurité et ③ convient aux applications de petite et moyenne taille.

See all articles