网站搭建:从0到1搭建网站

1 网站基本概念

网站说白了就是把一些东西放到哪里供其余人访问,并提供了一些能够交互的接口的地方。若是要实现这样一个地方首先,须要一个能放东西的地方这就是服务器。其次,咱们要找到这个地方,然而有不少这样的地方,因此咱们就须要给不少这样的地方标号,而后按照标号来找到这些地方,并访问。因此就有了IP地址,每一个服务器都有一个惟一的IP地址,这样咱们能够经过IP地址找到服务器。最后,IP地址都是一堆数字太难记了,有那么多服务器(相应的就有那么多IP地址),根据一串数字来找到服务器对于咱们来讲太麻烦了,根本记不住。若是有个名字就行了,好比百度的服务器能够用www.baidu.com来记那就好多了。因此就有了域名。为了咱们可以用域名来找到服务器,咱们须要把各个域名与服务器的IP地址映射起来来。每次当咱们用域名来访问服务器的时候,就须要把域名转换为IP地址(这个过程就是DNS(Domain Name System)服务),而后经过IP地址找到服务器。php

实际上这些概念实现上很复杂,分别在互联网七层协议中的不一样层实现。它们之间层与层之间相互依赖。实际状况也比较复杂,好比从域名到IP的映射之间能够多个域名映射到同一个IP,这就是虚拟主机的概念。不过这些都是后话了。接下来对各个概念尽心详细的解释。html

1.1 服务器概念

服务器(server),是提供计算机服务的设备。因为服务器须要响应服务请求,并进行处理,所以通常来讲服务器应具有承担服务而且保证服务的能力。mysql

服务器的构成包括处理器、硬盘、内存、系统总线等,和通用的计算机架构相似,可是因为须要提供高可靠的服务,所以在处理能力、稳定性、可靠性、安全性、可扩展性、可管理性等昂面要求较高。web

在网络环境下,根据服务器提供的服务类型不一样,分为文件服务器,数据库服务器,应用程序服务器,WEB服务器等。sql

总的来讲服务器就是可以提供服务的机器,这取决于机器上所安装的软件(服务软件),好比:Web服务器提供Web服务(网站访问),就须要Web服务软件,如Apache、tomact等。shell

1.2 IP的概念

IP:Internet Protocol,网络之间互联协议。网络之间互联的协议也就是计算机网络相互链接进行通讯而设计的协议。在因特网中,它是能连接到网上的全部计算机网络实现相互通讯的一套规则,规定了计算机在因特网上进行通讯时应当遵照的规则。任何厂家生产的计算机系统,只要遵照了IP协议就能够与因特网互联互通。IP地址具备惟一性。数据库

1.3 域名

域名(Domain Name),是由一串用点分隔的名字构成(www.baidu.com)的Internet上某一台计算机或计算机组成的名称,用于在数据串数时标识计算机的电子方位(有时也指地理位置,地理上的域名,指代有行政自主权的一个地方区域)。域名时一个IP地址上的“面具”。一个域名的目的是便于记忆和沟通的一组服务器的地址(网站,电子邮件,FTP等)。域名做为力所能及难忘的互联网参与者的名称。apache

1.4 DNS

DNS(Domain Name System,域名系统),因特网上做为域名和IP地址相互映射的一个分布式数据库,可以是用户更方便的访问互联网,而不用去记住可以被机器直接读取的IP数串。经过主机名,最终获得该主机名对应的IP地址的过程叫做域名解析(或主机名解析)。windows

1.5 端口

端口(Port),能够认为设备与外界通信交流的出口。主要为了解决,一台服务器上有很服务程序咱们访问一台服务器的时候如何判断咱们要要访问那种服务程序的问题。好比网页服务(http访问)的端口都为80。端口可分为虚拟端口和物理端口,其中虚拟端口指计算机内部或交换机路由器内的端口,不可见。例如计算机中的80端口、21端口、23端口等。物理端口又称为接口,是可见端口。浏览器

2 当咱们在浏览器中输入一个网址后发生了什么

前面说过域名只是IP地址的"面具",因此当咱们在浏览器中输入了域名后,首先要作的是解析域名,找到域名所对应的IP地址。这个时候浏览器会先访问本地DNS服务。说白了就是在本地电脑里保存了一个文件(windows中是hosts),该文件中记录了域名与IP地址的映射,若是你输入的域名在该文件中,则浏览器会直接访问该域名对应的IP地址所对应的服务器。若是本地DNS文件中没有该域名,则浏览器会访问DNS服务器(DNS服务器的IP地址就几个,且比较固定,好比114.114.114.114),在DNS服务器上查询该域名所对应的IP。
查到IP后,浏览器则访问该IP所指向的服务器,而后向服务器提出请求,服务器回应后,发送相应的内容到本机,显示在浏览器中。

DNS解析域名的过程和访问IP的过程当中还有不少机制,这里不详细说。

3 静态网页与动态网页

3.1 静态网页及其访问过程

称为普通网页。静态网页是指编写完成后,内容就不会在变化的,无论何人什么时候访问,显示的内容都是同样的。若是要修改网页的内容就必须修改其源代码,而后从新上传到服务器上。通常指.html、.htm、.xml文件等。能够直接打开用浏览其查看的。其访问过程以下图(以Apache为例):

这里写图片描述

3.2 动态网页及其访问过程

动态网页指在网页文件中除了HTML标记外,还包括一些实现特定功能的程序代码,这些程序代码使得浏览器与服务器之间能够进行交互,即服务器端能够根据客户端的不一样请求动态产生网页内容。动态网页的后缀名一般根据所用的程序设计语言的不一样而不一样,通常为.asp、.aspx、.cgi、.php、.perl、.jsp等。动态网页能够根据不一样的时间,不一样的浏览器者显示不一样的信息。其访问流程以下(以php为例):

这里写图片描述

4 服务器环境搭建

由于没有购买服务器,也没有注册域名。咱们计划在本地搭建一个服务器环境,把咱们本身本地计算机做为一个服务器。经过本地DNS重映射域名到咱们本机的IP地址(127.0.0.1),这样和实际搭建服务器没有大的区别,惟一的区别是作这些操做水在另外一个IP地址的计算机上进行的,域名也是通过注册(开通DNS服务的),在工信部通过备案的。

这里咱们选择Apache2.4服务器软件,php7语言,Mysql5.7数据库。

4.1 软件下载

Apache2.4,文件名:httpd-2.4.33-win64-VC15.zip。官方没有提供windows编译版本,这里是在pachelounge社区下载的:

https://www.apachelounge.com/download/

php7.2.6,文件名:VC15 x64 Thread Safe:

https://windows.php.net/download/

MySQL5.7.22,文件名:mysql-5.7.22-winx64(下载须要注册帐号):

https://dev.mysql.com/downloads/mysql/5.7.html#downloads

4.2 Apache安装

下载并解压文件,这里为方便管理,把Apache、php、mysql放在同一个文件夹下了。这里目录为“D:\Server\Apache”。

4.2.1 Apache目录解释

这里写图片描述

4.2.2 安装

以管理员身份启动cmd,而后进入Apache目录,调用一下命令:

httpd -k install -n apache
net start apache
httpd -n "apache" -t

以上命令分别是安装apache服务,并命名为“apache”;启动apache服务;若是启动不成功,第三行则能够查看缘由。启动成功。第三行则起测试做用测试做用。运行结果以下图:

这里写图片描述

另外,卸载Apache服务方法,是以管理员身份运行cmd,而后输入:sc delete Apache().

Apache(),表示你安装的Apache服务名字,有多是Apache,也多是Apache2.4,是能够在安装的时候指定的。

4.2.3 配置Apache

在"D:\Server\Apache\conf"目录下有个名为"httpd.conf"的文件,用记事本打开。并修改一些内容,以下:

一、服务器根目录,ServerRoot

修改前:ServerRoot "c:/Apache24"

修改后:ServerRoot "D:/Server/Apache",这个目录是Apache的安装目录,根据本身的目录作相应的修改。

二、服务名称
修改前:#ServerName www.example.com:80
修改后:ServerName localhost:80
三、Apache默认网站目录

修改前:DocumentRoot "c:/Apache24/htdocs"

修改后:DocumentRoot "D:/Documents/MyProjects/Web/",这个目录是本身网页文件的放置目录,就是网站文件都在该文件夹下。是本身定义的。

四、修改根目录选项

修改前:

<Directory "c:/Apache24/htdocs">

    Options Indexes FollowSymLinks

    AllowOverride None

    Require all granted

</Directory>

修改后:

<Directory "D:/Documents/MyProjects/Web/">

    Options Indexes FollowSymLinks

    AllowOverride None

    Require all granted

</Directory>
4.2.4修改本地DNS映射

在文件夹"C:\Windows\System32\drivers\etc"下面有个名为hosts的文件,用记事本打开,并添加以下一行:

127.0.0.1 localhost

这里是告诉浏览器,把localhost这个域名映射到IP地址为127.0.0.1的服务器,而127.0.0.1指向的服务器就是本机。

4.2.5 启动Apache,并测试

在Apache网站根目录里放入html文件,这里为"D:/Documents/MyProjects/Web/",就是在4.2.3中修改的目录。

注意,apache默认打开的文件是index.html。因此咱们在"D:/Documents/MyProjects/Web/"中建立名为index.html的文件,并编辑如下内容:

<!DOCTYPE html>
<html lang="en">

<body>

    Hello world !
</body>
</html>

启动Apache,在"D:\Server\Apache\bin"下有个名为ApacheMonitor.exe的程序,能够经过它来管理Apache的启动、关闭与重启。双击,启动后在任务栏右下角有个图标,左击而后启动Apache服务。

在浏览器地址栏输入:"http://localhost/"结果以下:

这里写图片描述

4.3 php安装

下载并解压文件,这里放的目录为:“D:\Server\php”,php目录介绍以下图:

这里写图片描述

4.4 mysql安装

mysql安装要注意有两个目录,一个是mysql自己的安装目录,另外一个是mysql中数据存放的目录。为方便管理这两个目录放在了同一个目录下:

mysql的安装目录:"D:\Server\mysql"
mysql的数据存放目录:“D:\Server\mysql\data”

一、把文件解压到"D:\Server\mysql" ,而后在该文件夹中建立data目录。mysql目录介绍以下图:

这里写图片描述

二、把“D:\Server\mysql\bin”,添加到环境变量,为了方便在cmd中调用mysql命令,不然每次调用mysql命令都要输入路径,或者先经过cmd进入该文件夹。

三、建立mysql配置文件
在目录"D:\Server\mysql" 中建立"my.ini"文件,内容以下:

[client]
port=3306
default-character-set=utf8
[mysqld]
port=3306
character_set_server=utf8
basedir=D:/Server/mysql
datadir=D:/Server/mysql/data

四、初始化数据库

mysqld --initialize
mysqld -install MySQL
net start MySQL

其中命令依次为,初始化数据库,安装数据库服务,启动数据库服务

五、修改数据库密码
在“D:\Server\mysql\data” 文件夹下有个名字为xxxxxx.err的文件夹,"xxxxxx"是计算机名。找到该文件并打开,找到"[Note] A temporary password is generated for root@localhost: "。改行后的是初始化数据库root帐号的默认密码,咱们就是要修改该密码:

mysql -u root -p
Enter password: ***********
set password for root@localhost = password('新密码');

注意:修改数据库密码命令后面的';'不能丢。若是想退出mysql,则输入quit,回车就能够了。
以下图:

这里写图片描述

4.5 Apache配置php

咱们刚才只是把Apache、php、mysql安装了,它们之间兵们有什么关系,咱们须要让他们协同起来一块儿工做。Apache须要调用php服务,php须要调用mysql服务。先Apache配置php。
一、构造php配置文件
在目录"D:\Server\php"中有个名为php.ini-development的文件,复制一份,并重命名为php.ini,放在该文件夹中。这个是php的配置文件。
二、修改Apache配置文件
打开httpd.conf文件,目录为"D:\Server\Apache\conf",在里面添加以下几行:

PHPIniDir "D:/Server/php/"
LoadModule php7_module "D:/Server/php/php7apache2_4.dll"
AddType application/x-httpd-php .php .html .htm

第一行是加载php配置文件,第二行是加载php中的一个动态连接库,第三行是把后缀名为.php、.html、.htm的文件交给apache来处理。

到此apache已经配置完php了,如今apache已经能够解析php文件了。在Apache网站根目录里建立一个名为index.php的文件,并编写如下内容:

<?php
phpinfo();
?>

重启apache。注意:全部对apache配置后都须要重启apache后才能生效。并在浏览器地址栏输入“http://localhost/index.php”,以下图:

这里写图片描述

4.6 php加载MySQL

用记事本打开php.ini文件,这里目录为"D:\Server\php"

添加以下几行:

extension_dir = "D:/Server/php/ext"
extension=php_mysqli.dll
extension=php_pdo_mysql.dll

第一行是设置php扩展模块的目录,第二行和第三行都是加载mysql的动态连接库。

到此,php已经能够连接数据库,并访问数据库了。在Apache网站根目录里建立一个名为index.php的文件,并编写如下内容:

<?php

$host = "127.0.0.1"; //mysql主机地址
$user = "root"; //mysql 登陆帐户
$pwd = "你本身的mysql密码"; //mysql登陆密码
$conn = new mysqli($host, $user, $pwd); //链接数据库
if (!$conn) {//判断
    echo '链接数据库失败: ' . mysql_error();
}
echo "mysql 链接成功!";
mysqli_close($conn); // 关闭mysql链接

?>

重启apache。注意:全部对apache配置后都须要重启apache后才能生效。并在浏览器地址栏输入“http://localhost/index.php”,以下图:

这里写图片描述

到此网站服务器环境已经配置完成了,只要在apache网站默认目录中放入网站的代码就能够了。

5 虚拟主机设置

以前说过多个域名能够映射到同一个服务器,也就是说一个服务器是能够同时挂在多个网站的。只要域名解析到该服务器,apache会把域名映射到一个文件夹中,也就是说这里的一个域名所对应的只是服务器上的一个文件夹而已。这里能够想一想,若是apache(或者其余的本身开发的web服务软件)不是把域名映射到一个文件夹,而是映射到一个IP的话,这应该就是咱们购买服务器时候说的公网IP和内网IP中的内网IP了把。而安装web服务软件的把域名映射到新IP的那个服务器的IP应该就是公网IP了。言归正传,设置虚拟主机主要仍是apache配置问题,步骤以下:

一、加载httpd-vhosts.conf文件

打开httpd.conf文件,并找到Virtual hosts一项以下图:

这里写图片描述

把#Include conf/extra/httpd-vhosts.conf,前的"#"删除,表示加载httpd-vhosts.conf这个文件。

二、修改httpd-vhosts.conf文件
打开httpd-vhosts.conf文件,目录在 "D:\Server\Apache\conf\extra",把原来的内容删除掉,添加以下:

<VirtualHost *:80>
    DocumentRoot "D:/Documents/MyProjects/Web"
    ServerName localhost
    <Directory "D:/Documents/MyProjects/Web">
    Options Indexes FollowSymLinks
    AllowOverride None
    Require all granted
    </Directory>
</VirtualHost>

<VirtualHost *:80>
    DocumentRoot "D:/Documents/MyProjects/BlogWeb"
    ServerName www.denverBlog.com
    <Directory "D:/Documents/MyProjects/BlogWeb">
    Options Indexes FollowSymLinks
    AllowOverride None
    Require all granted
    </Directory>
</VirtualHost>

其中第一个 是apache的默认目录,若是加载了httpd-vhosts.conf文件必须则必须在httpd-vhosts.conf中添加默认目录的部分,不然默认目录不能访问。

第二个 则是咱们添加的另外一个虚拟主机的目录,其中

DocumentRoot :表示该虚拟主机的文件目录;

ServerName:表示该虚拟主机的域名。
<Directory "D:/Documents/MyProjects/BlogWeb">:则是该虚拟主机目录的访问权限设置。这里咱们是直接从httpd.conf文件文件中复制过来的。

三、给虚拟主机添加本地DNS映射
咱们虚拟主机的域名为www.denverBlog.com,正常状况下这个域名是通过注册和备案后指向咱们购买的服务器的IP的,可是咱们没有服务器,也没有注册域名,仍是指向本地计算机。因此咱们在本地DNS中添加www.denverBlog.com映射到本地ip:127.0.0.1。操做方法和4.2.4中同样:

在文件夹"C:\Windows\System32\drivers\etc"下面有个名为hosts的文件,用记事本打开,并添加以下一行:

127.0.0.1 www.denverBlog.com

到此咱们就可用经过域名www.denverBlog.com来访问“D:/Documents/MyProjects/BlogWeb”文件下的网页内容了。要注意在实际的网站中,这个文件夹和apache文件夹都是在服务器上的,也就是说咱们在一个服务器中建立了两个网站,经过两个域名分别来访问它们。而对于服务器和apache来讲,这两个网站只是服务器上的两个目录而已。一样的咱们能够用这种方式建立n个虚拟主机,不过要考虑到apache的处理能力。

而后重启apache,就能够正常使用了。注意:全部对apache配置后都须要重启apache后才能生效。

四、测试

在"D:/Documents/MyProjects/BlogWeb"中建立一个php文件,并编辑以下内容:

<?php
        echo "Hellow world";

        $host = "127.0.0.1"; //mysql主机地址
        $user = "root"; //mysql 登陆帐户
        $pwd = "scu@hzq159786"; //mysql登陆密码
        $conn = new mysqli($host, $user, $pwd); //链接数据库
        if (!$conn) {//判断
            echo '链接数据库失败: ' . mysql_error();
        }
        echo "mysql 链接成功!";
        mysqli_close($conn); // 关闭mysql链接

        phpinfo();
?>

在浏览器中输入http://www.denverblog.com/,结果以下:

这里写图片描述

相关文章
相关标签/搜索