linux web目录 linux如何搭建web环境
大家好,关于linux web目录很多朋友都还不太明白,不过没关系,因为今天小编就来为大家分享关于linux如何搭建web环境的知识点,相信应该可以解决大家的一些困惑和问题,如果碰巧可以解决您的问题,还望关注下本站哦,希望对各位有所帮助!
nginx的默认web目录在哪
Nginx的默认web目录在不同的安装方式下会有所不同。使用yum安装的Nginx,其默认web目录通常位于/usr/share/nginx/html/。这是大多数Linux发行版默认的安装路径,适用于快速安装和简单的配置需求。
而通过源码安装的Nginx,其默认web目录则位于/usr/local/nginx/html/。这种方式允许用户根据自身需求进行更详细的配置和定制,特别是在企业级环境中,可能需要更精细的管理权限和配置选项。
值得注意的是,这些默认路径可以通过修改Nginx的配置文件来更改。例如,可以通过编辑nginx.conf文件中的server块来指定不同的文档根目录,从而改变默认的web目录位置。这为用户提供了更大的灵活性,可以根据实际需要调整Nginx服务器的工作方式。
在实际部署中,根据安装方式选择合适的默认web目录是必要的,以确保Nginx能够正确地提供静态内容服务。对于开发和测试环境,使用默认路径通常已经足够;而在生产环境中,为了安全性和性能考虑,可能会选择不同的目录结构,并进行相应的权限配置。
此外,用户还可以利用Nginx的模块功能,进一步扩展和定制其功能。例如,可以通过安装额外的模块来支持更复杂的静态资源处理、负载均衡等高级功能,这将使Nginx能够更好地满足不同场景下的需求。
在linux的服务器下怎么知道根目录是什么
就相当于windows系统的C盘
下面是介绍根目录下的文件夹意义:
/:根目录,位于linux文件系统目录结构的顶层,一般根目录下只存放目录,不要存放文件,/etc、/bin、/dev、/lib、/sbin应该和根目录放置在一个分区中。
/bin,/usr/bin:该目录为命令文件目录,也称为二进制目录。包含了供系统管理员及普通用户使用的重要的linux命令和二进制(可执行)文件,包含shell解释器等。
/boot:该目录中存放系统的内核文件和引导装载程序文件,/boot/vmlinuz为linux的内核文件,以及/boot/gurb。建议单独分区,分区大小100M即可。
/dev:设备(device)文件目录,存放linux系统下的设备文件,访问该目录下某个文件,相当于访问某个设备,存放连接到计算机上的设备(终端、磁盘驱动器、光驱及网卡等)的对应文件,包括字符设备和块设备等,常用的是挂载光驱mount/dev/cdrom/mnt。
/etc:系统配置文件存放的目录,该目录存放系统的大部分配置文件和子目录,不建议在此目录下存放可执行文件,重要的配置文件有/etc/inittab、/etc/fstab、/etc/init.d、/etc/X11(X Window系统有关)、/etc/sysconfig(与网络有关)、/etc/xinetd.d修改配置文件之前记得备份。该目录下的文件由系统管理员来使用,普通用户对大部分文件有只读权限。
/home:系统默认的用户宿主目录,新增用户账号时,用户的宿主目录都存放在此目录下,~表示当前用户的宿主目录,~test表示用户test的宿主目录。建议单独分区,并设置较大的磁盘空间,方便用户存放数据。
/lib,/usr/lib,/usr/local/lib:系统使用的函数库的目录,程序在执行过程中,需要调用一些额外的参数时需要函数库的协助,该目录下存放了各种编程语言库。典型的linux系统包含了C、 C++和FORTRAN语言的库文件。/lib目录下的库映像文件可以用来启动系统并执行一些命令,目录/lib/modules包含了可加载的内核模块,/lib目录存放了所有重要的库文件,其他的库文件则大部分存放在/usr/lib目录下。
/lost+fount:在EXT2或EXT3文件系统中,当系统意外崩溃或机器意外关机,产生的一些文件碎片放在这里。在系统启动的过程中fsck工具会检查这里,并修复已经损坏的文件系统。有时系统发生问题,有很多的文件被移到这个目录中,可能会用手工的方法来修复,或者移动文件到运来的位置上
/mnt,/media: mnt目录主要用来临时挂载文件系统,为某些设备提供默认挂载点,如floppy,cdrom。这样当挂载了一个设备如光驱时,就可以通过访问目录/mnt/cdrom下的文件来访问相应的光驱上的文件了。
/opt:给主机额外安装软件所摆放的目录。如:FC4使用的Fedora社群开发软件,如果想要自行安装新的KDE桌面软件,可以将该软件安装在该目录下。以前的 Linux系统中,习惯放置在/usr/local目录下。
/proc:此目录的数据都在内存中,如系统核心,外部设备,网络状态,由于数据都存放于内存中,所以不占用磁盘空间,比较重要的目录有/proc/cpuinfo、/proc/interrupts、/proc/dma、/proc/ioports、/proc/net/*等。
/root:系统管理员root的宿主目录,系统第一个启动的分区为/,所以最好将/root和/放置在一个分区下。
/sbin,/usr/sbin,/usr/local/sbin:放置系统管理员使用的可执行命令,如fdisk、shutdown、mount等。与/bin不同的是,这几个目录是给系统管理员root使用的命令,一般用户只能"查看"而不能设置和使用。
/tmp:一般用户或正在执行的程序临时存放文件的目录,任何人都可以访问,重要数据不可放置在此目录下。
/srv:服务启动之后需要访问的数据目录,如www服务需要访问的网页数据存放在/srv/www内。
/usr:应用程序存放目录,/usr/bin存放应用程序,/usr/share存放共享数据,/usr/lib存放不能直接运行的,却是许多程序运行所必需的一些函数库文件,/usr/local存放软件升级包,/usr/share/doc系统说明文件存放目录。/usr/share/man:程序说明文件存放目录,使用 man ls时会查询/usr/share/man/man1/ls.1.gz的内容建议单独分区,设置较大的磁盘空间。
/var:放置系统执行过程中经常变化的文件,如随时更改的日志文件/var/log。/var/log/message:所有的登录文件存放目录。/var/spool/mail:邮件存放的目录。/var/run:程序或服务启动后。建议单独分区,设置较大的磁盘空间。
/tmp:存放临时文件目录,一些命令和应用程序会用的到这个目录。该目录下的所有文件会被定时删除,以避免临时文件占满整个磁盘。
/dev目录
dev是设备(device)的英文缩写。/dev这个目录对所有的用户都十分重要。因为在这个目录中包含了所有Linux系统中使用的外部设备。但是这里并不是放的外部设备的驱动程序,这一点和windows,dos操作系统不一样。它实际上是一个访问这些外部设备的端口。我们可以非常方便地去访问这些外部设备,和访问一个文件,一个目录没有任何区别。
Linux沿袭Unix的风格,将所有设备认成是一个文件。
设备文件分为两种:块设备文件(b)和字符设备文件(c),设备文件一般存放在/dev目录下,对常见设备文件作如下说明:
/dev/hd[a-t]:IDE设备
/dev/sd[a-z]:SCSI设备
/dev/fd[0-7]:标准软驱
/dev/md[0-31]:软raid设备
/dev/loop[0-7]:本地回环设备
/dev/ram[0-15]:内存
/dev/null:无限数据接收设备,相当于黑洞
/dev/zero:无限零资源
/dev/tty[0-63]:虚拟终端
/dev/ttyS[0-3]:串口
/dev/lp[0-3]:并口
/dev/console:控制台
/dev/fb[0-31]:framebuffer
/dev/cdrom=>/dev/hdc
/dev/modem=>/dev/ttyS[0-9]
/dev/pilot=>/dev/ttyS[0-9]
/dev/random:随机数设备
/dev/urandom:随机数设备
/etc目录
/etc/rc,/etc/rc.d,/etc/rc*.d启动、或改变运行级时运行的scripts或scripts的目录。
/etc/passwd用户数据库,其中的域给出了用户名、真实姓名、家目录、加密的口令和用户的其他信息。
/etc/fstab启动时mount-a命令(在/etc/rc或等效的启动文件中)自动mount的文件系统列表。Linux下,也包括用swapon-a启用的swap区的信息。
/etc/group类似/etc/passwd,但说明的不是用户而是用户组。
/etc/inittab init的配置文件,设定系统启动时init进程将把系统设置成什么样的runlevel。
/etc/issue getty在登录提示符前的输出信息.通常包括系统的一段短说明或欢迎信息内容由系统管理员确定。
/etc/motd Message Of The Day,成功登录后自动输出内容由系统管理员确定,经常用于通告信息,如计划关机时间的警告。
/etc/mtab当前安装的文件系统列表.由scripts初始化,并由mount命令自动更新,需要一个当前安装的文件系统的列表时使用,例如df命令。
/etc/shadow在安装了影子口令软件的系统上的影子口令文件.影子口令文件将/etc/passwd文件中的加密口令移动到/etc/shadow中,而后者只对root可读这使破译口令更困难.
/etc/login.defs login命令的配置文件。
/etc/printcap类似/etc/termcap,但针对打印机语法不同。
/etc/profile,/etc/csh.login,/etc/csh.cshrc登录或启动时Bourne或C shells执行的文件,这允许系统管理员为所有用户建立全局缺省环境。
/etc/securetty确认安全终端,即哪个终端允许root登录.一般只列出虚拟控制台,这样就不可能(至少很困难)通过modem或网络闯入系统并得到超级用户特权。
/etc/shells列出可信任的shell.chsh命令允许用户在本文件指定范围内改变登录shell.提供一台机器FTP服务的服务进程ftpd检查用户shell是否列在/etc/shells文件中,如果不是将不允许该用户登录.
/etc/sysconfig网络配置相关目录
/etc/DIR_COLORS设定颜色
/etc/HOSTNAME设定用户的节点名
/etc/NETWORKING只有YES标明网络存在
/etc/host.conf文件说明用户的系统如何查询节点名
/etc/hosts设定用户自已的IP与名字的对应表
/etc/hosts.allow设置允许使用inetd的机器使用
/etc/hosts.deny设置不允许使用inetd的机器使用
/etc/hosts.equiv设置远端机不用密码
/etc/inetd.conf设定系统网络守护进程inetd的配置
/etc/inetd.pid inetd这个进程的进程id
/etc/hosts.lpd设定远端有哪些节点可以使用本机的打印机
/etc/gateways设定路由器
/etc/protocols设定系统支持的协议
/etc/named.boot设定本机为名字服务器的配置文件
/etc/named.pid本机上运行的名字服务器的进程id
/etc/networks设定网络的配置文件
/etc/resolv.conf设定系统的名字服务器
/etc/services设定系统的端品与协议类型和提供的服务
/etc/exports设定NFS系统用的
/etc/NNTP_INEWS_DOMAIN设置新闻服务器的配置文件
/etc/nntpserver设置用户使用的新闻服务器的地址
/etc/XF86Config X Window的配置文件
/etc/hostid系统独有的一个硬件id
/etc/at.deny设置哪些用户不能使用at命令
/etc/bootptab给MAKEDEV程序设定各种不同的设备驱动文件的格式
/etc/makedev.cfg同DEVINFO一样给MAKEDEV使用的设置文件
/etc/diphosts设置拔号服务器的用户名和口令
/etc/slip.hosts,/etc/slip.login设定SLIP的配置文件
/etc/fastboot使用shutdown-f产生的,重启系统要查这个文件
/etc/fstab记录开机要mount的文件系统
/etc/ftpaccess FTP服务器的一些配置
/etc/ftpconversions设定在FTP时使用的过滤器的位置
/etc/ftpusers设定不能使用FTP服务的用户
/etc/ld.so.cache查找系统动态链接库的缓存
/etc/ld.so.conf系统动态链接库的路径
/etc/lilo.conf lilo的配置文件
/etc/magic给file命令使用的
/etc/aliases给sendmail使用的设置别名的文件
/etc/mail.rc,
/etc/mailcap,
/etc/sendmail.cf,
/etc/sendmail.st设置sendmail的
/etc/motd超级用户发布通知的地方
/etc/organization存放用户的名字和组织
/etc/pnpdevices列出支持的Plug&Play设备
/etc/snooptad监控用户的屏幕,监听的终端列表
/etc/sudoers可以sudo命令的配置文件
/etc/syslog.conf系统记录程序syslogd的配置文件
/etc/utmp目前在用系统的用户信息
/etc/wtmp同utmp差不多,只是它累加
/etc/nologin系统在shutdown时不希望用户登录就产生这个文件
/etc/termcap设置系统终端信息的
/etc/ttys设定系统的终端类型
/etc/gettydefs getty_ps的定义文件
/etc/yp.conf NIS的配置文件
/etc/mtools.conf设定mtools程序的参数
/etc/fdprm设定格式化软盘的参数
/etc/login.access控制用户登录权限的文件
/proc目录
/proc/cmdline加载 kernel时所下达的相关参数,查阅此文件,可了解系统是如何启动。
/proc/cpuinfo本机的 CPU的相关资讯,包含时脉、类型与运算功能等
/proc/devices这个文件记录了系统各个主要装置的主要装置代号,与 mknod有关。
/proc/filesystems目前系统已经加载的文件系统。
/proc/interrupts目前系统上面的 IRQ分配状态。
/proc/ioports目前系统上面各个装置所配置的 I/O位址。
/proc/kcore这个就是内存的大小,但是不要读他。
/proc/loadavg还记得 top以及 uptime吧?没错,上头的三个平均数值就是记录在此。
/proc/meminfo使用 free列出的内存资讯,在这里也能够查阅到。
/proc/modules目前我们的 Linux已经加载的模块列表,也可以想成是驱动程序。
/proc/mounts系统已经挂载的数据,就是用 mount这个命令呼叫出来的数据。
/proc/swaps到底系统挂加载的内存在哪里?使用掉的 partition就记录在此啦。
/proc/partitions使用 fdisk-l会出现目前所有的 partition吧?在这个文件当中也有纪录。
/proc/pci在 PCI汇流排上面,每个装置的详细情况,可用 lspci来查阅。
/proc/uptime就是用 uptime的时候,会出现的资讯。
/proc/version核心的版本,就是用 uname-a显示的内容。
/proc/bus/*一些汇流排的装置,还有 U盘的装置也记录在此。
/usr目录
/usr最庞大的目录,因为所有应用程序几乎都安装在这里,本地安装的程序和其他东西在/usr/local下。
/usr/etc存放配置文件。
/usr/games存放游戏和教学文件。
/usr/include开发和编译应用程序所需要的头文件。
/usr/share存放结构独立的数据。/usr/share/man,/usr/share/info,/usr/share/doc手册页、GNU信息文档和各种其他文档文件。
/usr/bin几乎所有用户命令.有些命令在/bin或/usr/local/bin中。
/usr/sbin根文件系统不必要的系统管理命令,例如多数服务程序。
/usr/lib程序或子系统的不变的数据文件,包括一些site-wide配置文件,名字lib来源于库(library),编程的原始库存在/usr/lib里。
/usr/local本地安装的软件和其他文件放在这里,/usr/local/bin存放本地增加的命令,/usr/local/include存放本地增加的库文件。
/usr/src存放程序的源代码,linux内核的源代码存放在/usr/src/kernels。
/var目录
/var包括系统一般运行时要改变的数据.每个系统是特定的,即不通过网络与其他计算机共享。
/var/catman当要求格式化时的man页的cache.man页的源文件一般存在/usr/man/man*中;有些man页可能有预格式化的版本,存在/usr/man/cat*中.而其他的man页在第一次看时需要格式化,格式化完的版本存在/var/man中,这样其他人再看相同的页时就无须等待格式化了.(/var/catman经常被清除,就象清除临时目录一样.)
/var/lib系统正常运行时要改变的文件。
/var/local,/usr/local中安装的程序的可变数据(即系统管理员安装的程序).注意,如果必要,即使本地安装的程序也会使用其他/var目录,例如/var/lock。
/var/lock锁定文件.许多程序遵循在/var/lock中产生一个锁定文件的约定,以支持他们正在使用某个特定的设备或文件.其他程序注意到这个锁定文件,将不试图使用这个设备或文件。
/var/log各种程序的Log文件,特别是login(/var/log/wtmp log所有到系统的登录和注销)和syslog(/var/log/messages里存储所有核心和系统程序信息./var/log里的文件经常不确定地增长,应该定期清除。
/var/run保存到下次引导前有效的关于系统的信息文件.例如,/var/run/utmp包含当前登录的用户的信息。
/var/spool,/var/mail,/var/news打印队列和其他队列工作的目录.每个不同的spool在/var/spool下有自己的子目录,例如,用户的邮箱在/var/spool/mail中。
/var/tmp比/tmp允许的大或需要存在较长时间的临时文件。(虽然系统管理员可能不允许/var/tmp有很旧的文件.)
比较重要的目录
在 Linux系统中,有几个目录是特别需要注意的,以下提供几个需要注意的目录,以及预设相关的用途:
/etc:这个目录相当重要,如前所述,你的开机与系统数据文件均在这个目录之下,因此当这个目录被破坏,那你的系统大概也就差不多该死掉了!而在往后的文件中,你会发现我们常常使用这个目录下的/etc/rc.d/init.d这个子目录,因为这个 init.d子目录是开启一些 Linux系统服务的 scripts(可以想成是批次档)的地方。而在/etc/rc.d/rc.local这个文件是开机的执行档。
/bin,/sbin,/usr/bin,/usr/sbin:这是系统预设的执行文件的放置目录,例如 root常常使用的 userconf, netconf, perl, gcc, c++等等的数据都放在这几个目录中,所以如果你在提示字符下找不到某个执行档时,可以在这四个目录中查一查!其中,/bin,/usr/bin是给系统使用者使用的指令,而/sbin,/usr/sbin则是给系统管理员使用的指令!
/usr/local:这是系统预设的让你安装你后来升级的套件的目录。例如,当你发现有更新的 Web套件(如 Apache)可以安装,而你又不想以 rpm的方式升级你的套件,则你可以将 apache这个套件安装在/usr/local底下。安装在这里有个好处,因为目前大家的系统都是差不多的,所以如果你的系统要让别人接管的话,也比较容易上手呀!也比较容易找的到数据喔!因此,如果有需要的话,通常会将/usr/local/bin这个路径加到自己的 path中。
/home:这个是系统将有账号的人口的家目录设置的地方。
/var:这个路径就重要了!不论是登入、各类服务的问题发生时的记录、以及常态性的服务记录等等,所以当你的系统有问题时,就需要来这个目录记录的文件数据中察看问题的所在啰!而 mail的预设放置也是在这里,所以他是很重要的。
/usr/share/man,/usr/local/man:这两个目录为放置各类套件说明档的地方,例如你如果执行 man man,则系统会自动去找这两个目录下的所有说明文件。
Linux下Web服务器架设攻略
今天我们来看看如何将Web服务器架在Linux系统下。
LINUX系统中常见的有:CERN、NCSA、Apache三种方式,一般最常用的方法就是用Apache。此种方式特点明显,配置简明,具有最大的对系统兼容性,以下是用此方式配置基于Linux的WEB服务器的全过程。
一. Apache服务器慨述。
其特征是显著的:可以运行于所有计算机平台,自然包括UNIX/LINUX系统;集成代理服务器和Perl编程脚本;对用户的访问会话过程跟踪;可对服务器日志定制;还支持虚拟主机及HTTP认证等等。再配合LINUX系统本身的强大,我们没理由不选择Apache。
二.安装Apache。
一般说来,所有Linux版本应该包含有此软件包的安装,如果你在安装Linux系统没有安装此软件包,可以从安装光盘或是网站上找到其安装文件(注意网上有两种版本:一种是下载后需重新编译的源代码,一种是只需解压就可使用的可执行文件),然后执行安装即可。
1.如果你下载的是可执行文件包如:apache_1.2.4.e.tar.gz(当中的数字视你下载的版本而定,此为举例),那这就相对简单,比较适合对Linux编译不熟悉的初级用户,只需执行:tar xvzf apache_1.2.3.4.tar.gz即可完成安装。
2.如果下载的是源代码如:apache_1.2.4.rpm,则先用rpm–ivh apache_1.2.4.rpm安装,然后在src目录下执行“./configure”;接着执行“make”命令编译Apache;接着将编译好的可执行文件复制到/etc/httpd/bin目录下;再将Apache的配置文件:httpd.conf、access.conf、srm.conf和mime.types复制到/etc/httpd/conf目录下,才算完成安装。
三.配置Apache,实现WEB服务。
其实,到现在你的Linux已经开始WEB服务了,你要做的只需将Linux系统连入互联网,然后将主页存放于“/home/httpd”目录下即可。但为了让此WEB服务器更有效率的工作,我们还需对其作些设置,具体需要配置的其实就是刚才复制的那4个文件。以下对其主要的两个配置文件httpd.conf和access.conf作些说明:
1. httpd.conf.
此文件是主配置文件,主要用来设置服务器启动的基本环境,也就是说它负责安排WEB服务器怎样运行。其相关设置参数为:
ServerTypestandalone/inetd:此选项作用就是指定以何种方式运行WEB服务器。其中standalone参数表示WEB服务进程以一个单独的守候进程的方式在后台侦听是否有客户端的请求,如果有就生成一个子进程来为其服务;其效率更高。主要是设置主服务器进程侦听的特定端口地址,方法为:Port[number](缺省为80)。
而inetd模式相对standalone来说它更安全,此模式也是RedHat Linux运行Apache的默认方式。如果你的版本不是RedHat,则需在/etc/inetd.conf文件里加入以下一新行:httpd stream tcp nowait httpd/etc/httpd/bin/httpd–f/etc/httpd/conf/httpd.conf;然后在/etc/services文件里同样添加一新行:httpd 80/tcp httpd即可。
ErrorLog:用来指定错误记录的文件名称和路径。格式如:ErrorLog/var/httpd/error.log。
ServerRoot:用来指定将服务器的配置及日志文件存于何处。格式如:ServerRoot/etc/httpd。
Server Admin:设置WEB管理员的E-Mail地址.格式如:Server AdminXXX@XXXX.com。
2. srm.conf
这是Apache的资源配置文件,作用为告诉服务器你想在WWW站点上提供的资源及如何提供,其主要参数为:
DocumentRoot:用来指定主文档的地址。格式如:DocumentRoot/home/httpd/html。
DirectoryIndex:跟windows平台的IIS设置一样,用来指定首页文件的名称。大家都知道,首页一般都以“index.html”或“index.htm”作为文件名。当设置为这两种文件名之后,只要用户发出WEB请求,即将调入以“index.html”或“index.htm”命名的主页。格式如:DirecotryIndex index.html index.htm。
经过以上简单的配置后,你的WEB服务器已经具备基本的功能了。接下来要做的就是重启WEB服务,使刚才的配置生效,我们可以用以下命令来完成:
/etc/rc.d/init.d/httpd restart
最后,我们来看看基于Apache服务的安全方面。Apache服务器通过认证系统能控制哪些主机可以访问某些特定的站点。具体来说,它通过两种方式来实现:
一种是基于主机地址的认证,但由于目前大部分上网用户使用的都是动态地址,因此此种方式并没多少实际意义;
另一种方式是基于用户名/口令的认证方式,不言而喻,此种方式更适合如今的网络状况,而对于具体的用户名/口令认证实现,不在本文讨论范围,大家可以参阅相关资料作进一步学习。