如何在家中托管自己的云服务器

电子说

1.3w人已加入

描述

步骤1:先决条件

1。您希望上传到云的媒体。从现在开始,将当前存储媒体的设备称为客户端。

2。一台服务器。除非您打算要访问大量流量,否则服务器不必特别强大。我发现旧的戴尔计算机可以很好地用作云服务器。您需要担心的服务器主要部分是硬盘驱动器和内存。硬盘将数据存储在云中。硬盘驱动器的大小限制了可以在云中存储多少数据。服务器中的大量内存不是必需的,但是在传输大文件时可以提供帮助。我建议在云服务器中至少有1gb的内存。

3。 Ubuntu Server 14.04 LTS。这是将用于运行云的软件。该软件基于命令行,这意味着没有GUI。如果那让您担心,请不要惊慌!学习使用命令行令人兴奋。假设您按照本指南中的说明进行操作,则应该没有问题。在本指南中,我不会解释如何下载和刻录Ubuntu光盘,但是如果您需要帮助,请查看上一指南中的步骤2。

4。监视器。在服务器的初始配置期间,这是必需的。配置完成后,您可以取下显示器,键盘和鼠标。

此外,请确保将服务器放置在靠近路由器的以太网连接附近。与Wi-Fi相比,以太网连接非常重要,因为它更快,更可靠,如果您正在流传输电影等媒体,这将很有帮助。

接下来,我们将Ubuntu Server 14.04 LTS安装到服务器上。

步骤2:安装Ubuntu

1。首先将带有Ubuntu Server的CD/USB插入服务器。确保服务器设置为从USB引导。如果您不知道如何从CD/USB引导,请参阅此处的指南。 Ubuntu Server将加载,安装过程将开始。

2。首先,将显示语言屏幕。突出显示您的语言,然后按Enter继续。

3。接下来将显示Ubuntu Server启动屏幕。该屏幕包含用于安装和配置Ubuntu Server的服务器选项。突出显示“安装Ubuntu服务器”选项,然后按Enter继续。

4。接下来,在列表中突出显示适当的语言,然后按Enter继续。

5。在下一个屏幕上,突出显示您的位置,然后按Enter继续。

6。下一个屏幕将询问您是否希望Ubuntu检测键盘布局。非常欢迎您这样做,但是我通常选择不这样做。对于使用标准美式键盘的用户,您不需要使用此工具。按Enter继续。

7。下一个屏幕是键盘配置提示。突出显示您正在使用的键盘类型,然后按Enter继续。

8。一旦选择了键盘布局,Ubuntu可能会根据先前的选择要求您提供更具体的键盘布局。就我而言,Ubuntu只想知道我使用的是哪种英文(美国)键盘。突出显示适当的选项,然后按Enter(继续)。

9.接下来,Ubuntu将要求您为服务器提供一个主机名。主机名指的是如何在网络上知道服务器的名称。在我的演员表中,为简单起见,我为服务器指定了主机名“ ubuntu”。您可以为服务器指定任意主机名,但是请记住,本指南中使用的所有命令都将基于主机名“ ubuntu”。按Tab键,然后按Enter键继续。

10。然后,服务器将要求您在字段中输入您的姓名。您可以在此字段中输入所需的名称,因为它实际上没有任何意义。我选择在此字段中输入“服务器”。按Tab键,然后按Enter键继续。

11。接下来,安装程序将提示您输入服务器的用户名。用户名是用于访问服务器的登录凭据。在我的示例中,我选择了用户名“ server”。您可以为服务器提供所需的用户名,但是请记住,本指南中使用的所有命令都将基于用户名“ server”。按Tab键,然后按Enter键继续。

12。密码提示将出现在下一步。输入您在上一步中刚创建的用户的密码。按Tab键和Enter键继续。下一个提示将要求您重新输入密码。完成后,按Tab键和Enter键继续。

13。下一个提示符将询问您是否要加密主目录。如果您的计算机被盗,小偷将无法访问您的文件。加密为服务器增加了一层额外的安全保护,但同时也会降低性能。在此示例中,我选择不加密主目录。按Enter继续。

14。接下来是磁盘分区工具。因为在示例中我使用的是虚拟机,所以在安装中显示的选项可能与我的不同。假设您的硬盘驱动器不包含其他操作系统或分区,则应突出显示“引导-使用整个磁盘并设置LVM”或类似的东西。按Enter继续。

15。下一个提示符将要求您选择要分区的硬盘。如果服务器中仅安装了一个硬盘驱动器,它将是唯一显示的硬盘驱动器。如果服务器中安装了多个硬盘驱动器,请确保选择正确的磁盘。突出显示适当的选项,然后按Enter继续。

16。下一个屏幕将要求确认您的分区选择。查看您所做的选择,然后按Tab键,然后按Enter键继续。

17。 (可选)如果您使用虚拟机来安装Ubuntu Server(如本示例中的示例)。下一个提示将要求您输入选择用于Ubuntu的卷的百分比。输入适当的金额,然后按Tab键和Enter键继续。

18。 (可选)如果您使用的是虚拟机,则下一个提示将要求您在格式化驱动器之前确认选择。查看您的选择,然后按Tab和Enter继续。

19。如果您打算在您的Ubuntu服务器上使用代理,请在以下提示中输入代理,然后按Tab和Enter继续。如果没有,请按Enter继续。

20。然后,Ubuntu将提示您选择安装自动更新的方式。选择您想要的任何选项。我强烈建议您选择自动安装安全更新。高亮显示适当的选项,然后按Enter继续。

21。接下来,将显示一个软件选择提示。该提示列出了许多通常与Ubuntu Server结合使用的软件包。在我们的情况下,我们需要安装OpenSSH和LAMP Server。在这两个软件包的每一个上按空格键,然后按Tab和Enter继续。

22。然后,Ubuntu将安装您选择的所有软件包以及其他必要的软件包。在此过程中,安装程序将提示您输入MySQL的密码。输入密码,然后按Tab键和Enter键以继续。另一个提示将要求您重新输入密码。完成后,按Tab键和Enter键继续。请注意,您不必为MySQL输入密码,但是,我强烈建议您选择使用密码。

23。接下来,Ubuntu将询问您是否可以将GRUB安装到主引导记录中。 GRUB是Ubuntu用来加载其操作系统的工具。它也可以用作恢复工具。如果服务器上没有其他操作系统,请突出显示“是”,然后按Enter键继续。如果服务器上还有其他操作系统,请确定要使用哪个引导程序,并在此屏幕上进行适当的选择。

24。最后,Ubuntu将完成安装过程,并提示您重新引导服务器。按Enter继续。

此时,应该成功安装Ubuntu Server 14.04 LTS。接下来,将安装其他软件包以向服务器添加其他功能。

步骤3:配置Apache2

现在,需要配置Apache2。此配置允许自动脚本运行而不会遇到权限问题。首先,打开您的Ubuntu服务器。服务器启动后,终端将提示您输入用户名。输入您先前创建的用户名。在我的示例中,我将输入服务器。接下来,输入您为用户创建的密码。请注意,输入密码后屏幕上没有任何显示。成功登录后,键入:

sudo apt-get install apache2-utils

此软件包将安装可用于Apache 2的各种实用程序。完成后,将使用默认端口apache用于网络服务器的用途需要更改。默认情况下,Apache 2在端口80上侦听Web流量。由于许多ISP阻止在端口80上的传入流量,因此需要更改默认端口。如果未从端口80更改端口,则无法从外部网络访问Web服务器,这违背了云的目的。要更改默认端口号类型:

cd/etc/apache2

然后:

sudo nano ports.conf

此命令将打开文件名为ports.conf。需要将“侦听80”行更改为“侦听8080”。这会将端口apache2侦听从端口80更改为8080。大多数ISP都不会阻止此端口上的传入流量。完成后,按Ctrl + O,然后按Crtl + X保存文件并退出nano。

还有一个文件需要编辑,以确认从端口80更改为8080。类型:

启用了CD站点

然后

sudo nano 000-default.conf

将显示VirtualHost 80的行更改为VirtualHost8080。完成后,按Ctrl + O保存,然后按Ctrl + X退出。

接下来,要确保在将文件从客户端自动复制到服务器时没有权限问题,需要更改默认的Apache2操作目录。要更改默认目录,需要安装并激活userdir模块。为此,请键入:

sudo a2enmod userdir

安装完成后,请键入:

sudo service apache2 restart

这将重新启动apache2服务并更新apache2使用的默认路径。

接下来,键入cd将目录更改为主目录。然后键入:

mkdir public_html

这将创建apache2使用的文件夹。接下来,再次重新启动apache2以确保进行了更改。

类型:

sudo服务apache2 restart

最后,创建文件夹以存储最终将放置在云中的媒体。为此,请键入:

mkdir public_html/documents

mkdir public_html/pictures

mkdir public_html/movies

mkdir public_html/music

这将为文档,图片,电影和音乐创建目录。

现在已经配置了Apache2,但是在测试Web服务器之前,需要先配置路由器以进行端口转发。

步骤4:配置路由器

为了从外部网络访问云,必须将端口8080转发到服务器的IP地址。如果跳过端口转发,则路由器将继续阻止端口8080上的传入流量。

要进行端口转发,需要以下信息:

路由器的默认网关

服务器的本地ip地址。

要查找网络的默认网关,请键入命令route。路由器的默认网关将显示在“网关”字段中。网关将用于访问路由器配置实用程序。

要查找服务器的本地IP地址,请键入命令ifconfig。假设您的服务器通过有线连接与路由器连接,则该服务器的IP地址将列在eth0连接下。查找显示inet addr的字段。该地址后面的数字是服务器的本地IP地址。它应该看起来像192.168.xxx.xxx,其中x可以是0到255之间的任何数字。将这个数字写下来。

打开Web浏览器,然后在地址栏中键入默认网关地址。您的特定品牌路由器的路由器配置实用程序应打开。路由器很可能会要求用户名和密码,然后才能对配置进行任何更改。快速的Google搜索通常可以产生路由器的默认用户名和密码。

登录后,在网页上查找端口转发标签。我的路由器的端口转发页面在“应用程序和游戏”下列出,然后在“单端口转发”下列出。

在我的示例中,路由器要求我输入外部和内部端口号,以及将流量从该端口转发到的IP地址。在外部和内部端口号列中,我输入8080。在“到IP地址”列中,我输入192.168.2.186,这是服务器的本地IP。您的配置应该与此非常相似。

完成后,单击“保存”以保存设置。这应该是大多数路由器上唯一需要配置的东西。如果您的网络连接了外部防火墙,则可能需要允许8080端口上的流量通过。

既然路由器正在将流量转发到服务器,则该进行测试了。要从外部网络访问服务器,建议您使用手机的4G服务。要测试服务器,最后一个IP地址是必需的。在连接到本地网络的客户端上,在Google中键入“我的IP地址是什么”。然后,Google将显示您的公共IP地址。在连接4G的电话上,在Web浏览器的地址栏中键入以下内容:

PublicIPAddres:8080

其中PublicIPAddress是您的公共IP地址。 8080部分告诉Web浏览器访问端口8080而不是默认端口80上的网页。

如果apache2配置正确,则应显示apache2欢迎页面。在这种情况下,您就可以继续进行下一步了。如果看不到apache2页面,请确保使用正确的IP地址并正确执行了上述步骤。如果仍有问题,请在下面发表评论。

要访问先前创建的文档目录,可以键入:

PublicIPAddress :8080/〜用户名/documents

用服务器的用户名替换用户名。在我的示例中,我将输入服务器。地址的其余部分是您要访问的文件夹。例如,如果我想访问目录为〜/public_html/movies/UP!/的文件夹,则输入:

PublicIPAddress :8080/〜server/movies/UP!/

尽管已配置apache2,但它不是很安全。当前,任何人都可以访问Web服务器上的所有文件。为了防止这种情况的发生,下一步将使用用户名和密码验证系统。

步骤5:保护服务器

为防止整个世界访问您云中的媒体,需要实施密码身份验证。首先,通过键入以下内容将目录更改为public_html:

cd〜/public_html

然后

sudo nano .htaccess

不要忘记‘。 htaccess之前。点对用户隐藏文件。该文件将告诉Web服务器访问云需要用户名和密码。输入上述命令后,Nano将打开一个名为.htaccess的空白文件。在窗口中输入:

AuthType Basic

AuthName“需要密码”

AuthUserFile/home/用户名/。htpasswd

需要有效用户

确保将用户名替换为服务器的用户名。在我的示例中,用户名是server。

完成后,请按Ctrl + O保存并按Ctrl + X退出。下一个需要创建的文件是.htpasswd。该文件将包含云的已批准登录凭据的列表。

首先,键入cd将目录更改为主目录。

下一步,键入:

htpasswd -c/home/用户名/。htpasswd User

请确保将用户名替换为服务器的用户名,就像上面一样。另外,将 User 替换为您想要的任何名称。在 User 字段中指定的名称用作云的用户名。在我的示例中,我使用名称admin。输入后,服务器将创建.htpasswd文件,并提示您输入指定用户的密码。输入并确认您的密码以继续。

public_html目录中的所有文件夹现在都通过密码验证来保护。

要将其他用户添加到凭据列表中,请不要输入与上述相同的命令,而是键入:

htpasswd/home/用户名/。htpasswd 用户

如果键入与上述相同的命令,则最初创建的.htpasswd文件将被覆盖。

要在网络上测试密码身份验证-服务器。打开Web浏览器并输入:

PublicIPAddress :8080/〜用户名/

应出现一个框,提示您输入用户名和密码,以便访问页面上的内容。输入先前创建的用户名和密码,然后页面上的内容将变为可用。请注意,public_html文件夹内的所有目录都不需要.htaccess文件。由于父目录具有.htaccess文件,因此其下的所有目录都需要进行身份验证才能访问。

现在,由于云已受保护,因此您现在可以安全地开始向服务器添加媒体了。

步骤6:将公共IP地址映射到域名

此步骤是完全可选的。此步骤的目的是创建一个免费域名,该域名将您的公共IP地址映射到域名。这背后的原因很简单。 IP地址很难记住,有时ISP会更改您的公共IP地址。此步骤将使您的公共IP地址保持静态,并将其映射到域名。就像我之前说过的那样,此步骤是完全可选的。

要开始创建域名,请打开此网站并创建一个帐户。需要使用该帐户来创建域名。创建帐户后,登录网站并单击页面左侧显示 Subdomains 的按钮。接下来,点击 [添加] 按钮。在打开的页面中将创建域名。

将子域的类型保留为A。

在子域框中,输入您要呼叫网站的名称。例如,我称我的网站为apples。

在域框中,选择您希望网站驻留的域。只要您选择一个公共域,您在此处选择的选项就无关紧要。在我的示例中,我选择了mooo.com

在目的地框中,输入您的公共IP地址。要找到此地址,请在Google中键入“我的IP地址是什么”。

最后,单击“保存”。现在,该域应映射到您的公共IP地址。现在,无论何时要访问您的网站,您都可以使用所选的子域名和域名来访问它。例如,要访问电影,您可以输入:

www。 SubDomainName.Domain。 com:8080/〜用户名/电影/

其中子域名,域是您在上面选择的名称。如果我选择苹果作为我的子域名,并选择mooo.com作为我的域名,则需要在它们各自的区域中输入这些名称。

此步骤完成后,就该将媒体从客户端传输到服务器了。

步骤7:传输介质(Linux)

在此步骤中,客户端计算机上驻留的介质将被传输到新创建的云中。它们有多种将媒体传输到云的方法:复制和粘贴,拖放或FTP。尽管每个选项都很好并且运行良好,但它们并不是自动化的。每次在客户端计算机上更新任何媒体时,都必须将其手动传输到服务器。要解决此问题,需要一个自动脚本。我已经将我使用的脚本附加到了此步骤。我的客户端计算机运行Linux,所以这是Linux脚本。如果您的客户端计算机运行的是Windows,则可以使用FileZilla之类的软件将文件手动传输到服务器。

首先,请下载脚本并将其放置在服务器上的/home文件夹中。客户端计算机。打开脚本并对其进行编辑,以满足客户端计算机的需求。在脚本中,有四个rsync命令。每个文件夹对应一个媒体文件夹:一个文件夹用于存放文档,照片,媒体和音乐。以下是脚本中每个元素的说明:

rsync -u -r -v -e ssh --progress --delete --chmod = D775/path/to/your/media/documents/* YOUR_SERVER_NAME @ YOUR_DOMAIN NAME:〜/public_html/documents/--exclude = .htaccess --exclude = .htaccess〜

rsync-rsync是用于将媒体传输到服务器的服务。

-u-如果服务器上的文件较新,此选项将跳过复制文件。如果由于某种原因服务器上的文件比客户端计算机上的文件新,则不会在服务器上覆盖它。

-r-此选项以递归方式复制所有文件。

-v-此选项基本上告诉rsync使您知道它在做什么,而不是不输出任何数据到终端。可以通过在v前面添加其他破折号来增加详细程度。

-e-此命令后跟ssh告诉rsync通过SSH复制文件。如果通过Internet复制文件,此选项可确保安全性。为了成功使用此选项,必须在服务器上配置SSH。您还必须能够在不使用密码的情况下SSH到服务器。通过Google的快速搜索,您可以找到有关如何完成这两项任务的教程。如果仅通过本地网络复制文件,则实际上不需要此命令。

-progress-此选项显示rsync在复制过程中的进度。

- -delete-如果客户机上不再存在文件,则此选项将删除服务器上的文件。这意味着,如果您不小心删除了客户端计算机上的文件,运行了该脚本,并想从服务器上检索该文件,因为您并不想首先删除它,那么该文件就不会存在。

-chmod = D775-此选项为每个文件提供适当的云托管权限。如果取消此选项,则云目录中的文件夹将不会显示在网站上。

/path/to/your/media/documents/*-这是文档文件夹的路径。该命令末尾的/*确保传输文件文件夹中的所有文件。更改脚本以匹配每个媒体目录的路径。

YOUR_SERVER_NAME @ YOUR_DOMAIN NAME:〜/public_html/documents/-此命令是文件将被复制到的服务器目录的路径。用您的服务器名称替换YOUR_SERVER_NAME。在本指南中,它将是服务器。用您在上一步中创建的域名替换YOUR_DOMAIN_NAME。最后,将/documents/替换为要复制到的相应媒体文件夹。

-exclude = .htaccess --exclude = .htaccess〜-由于使用了--delete选项,因此这些文件可以可能会从服务器上删除,因为它们不在客户端计算机上。但是,由于这些文件保护了服务器,因此不应删除它们。此命令可防止它们被删除。

要运行脚本,请键入:

。/rsync_backup

如果出现权限被拒绝的错误类型:

chmod 755 rsync_backup

这时,脚本应该运行并且所有媒体都将被传输到服务器。要自动执行脚本,请尝试创建cron作业。另一个快速的Google搜索应该会生成一个有关如何完成此操作的简单教程。

可以从位于此处的github页面下载脚本。

第8步:下一步?

现在您的云服务器已启动并正在运行,在服务器上要实现许多不同的项目,软件和脚本。您可以在这里按照我的指南尝试创建VPN服务器。您还可以使用XBMC设置从服务器到任何计算机的流传输。在此之前的云指南中描述了该过程。另外,您可以尝试进行Web开发,并创建自己的网站。如果您希望从云端流式传输音乐,则有一个出色的开源音乐流式软件称为Ampache。

责任编辑:wv

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分