2019-06-26 18:25:32 weixin_43254438 阅读数 93
  • Linux系列之走进Linux新世界

    本课程为全新马哥Linux全套系列课程之一--Linux基础入门和架构了解,从Linux起源,Linux架构和Linux形成历史开始逐步讲解,让你彻彻底底了解Linux的诞生,之后介绍了Linux相关文化和核心组成结构,以及Linux常用命令和基本用法,课程由浅入深,讲授方法受到98%学员一致好评!

    20454 人正在学习 去看看 马永亮

临时关闭防火墙

在这里插入图片描述

永久关闭防火墙
在这里插入图片描述

通过linux访问文本网页

在这里插入图片描述

Nginx Rewrite

1.什么是rewrite

Rewrite即URL重写, 主要实现url地址重写, 以及重定向, 就是把传入Web的请求重定向到其他URL的过程。

2.Rewrite使用场景

1.URL地址跳转,例如用户访问old.com将其跳转到new.com , 或者当用户通过http的方式访问hs.com时,将其跳转至https的方式访问hs.com
2.URL伪静态, 将动态页面显示为静态页面方式的一种技术, 便于搜索引擎的录入, 同时减少动态URL地址对外暴露过多的参数, 提升更高的安全性。
3.搜索引擎SEO优化依赖于URL路径, 以便支持搜索引擎录入。
4.可以调整用户浏览的URL,看起来更规范,合乎开发及产品人员的需求。

防止恶意IP解析

server {
listen 80 default_server;
return 302 http://www.hs.com;
}

server {
listen 80;
server_name www.hs.com;
location / {
return 302 https://servernameserver_namerequest_uri;
}
}

LNMP的搭建和应用
LNMP的角色
LNMP就是Linux+Nginx+MySQL+PHP,
Linux作为服务器的操作系统
Nginx作为Web服务器
PHP作为解析动态脚本语言
MySQL即为数据库

Nginx服务本身不能处理PHP的请求,那么当用户发起PHP动态请求, Nginx又是如何进行处理的。
有两种方法:
1.将PHP页面的解析请求转发给Apache处理
2.将PHP页面的解析请求转发给php-fpm模块 *****
用户–>http协议–>Nginx–>fastcgi协议–>php-fpm

注意: fastcgi是nginx连接php-fpm之间的协议。

1.用户通过http协议发起请求,请求会先抵达LNMP架构中的Nginx
2.Nginx会根据用户的请求进行判断,这个判断是有Location进行完成
3.判断用户请求的是静态页面,Nginx直接进行处理
4.判断用户请求的是动态页面,Nginx会将该请求交给fastcgi协议下发
5.fastgi会将请求交给php-fpm管理进程, php-fpm管理进程接收到后会调用具体的工作线程wrapper
6.wrapper线程会调用php进行解析,如果只是解析代码php直接返回
7.如果有查询数据库操作,则由php连接数据库(用户 密码 IP)然后发起查询的操作
8.最终数据由mysql->php->php-fpm->fastcgi->nginx->http->user

#########

1.安装Nginx
#1.使用Nginx官方提供的rpm包

################################################
2.安装MySQL
原始步骤:
1.下载MySQL官方扩展源

rpm -ivh http://repo.mysql.com/yum/mysql-5.6-community/el/7/x86_64/mysql-community-release-el7-5.noarch.rpm

2.安装mysql5.6, 文件过大可能会导致下载缓慢

yum install mysql-community-server -y

实训步骤:
1.将mysql56.tar.gz通过xshell传到服务器上

mkdir /soft

cd /soft

2.解压缩

tar xf mysql56.tar.gz

3.安装mysql56(需要有yum库)

mount /dev/cdrom /mnt

yum install -y mysql5.6/*

3.启动数据库, 并加入开机自启动
[root@nginx ~]# systemctl start mysqld
[root@nginx ~]# systemctl enable mysqld

#4.由于mysql5.6默认管理员root的密码为空,服务器启动后,可以直接登录
[root@web01 ~]# mysql -uroot
……
mysql>

#5.为了安全,必须给root设置密码

mysqladmin -u root password 123.com

如果已经有密码,再次修改

mysqladmin -uroot -p123.com -password 123

#6.使用密码登陆mysql

mysql -uroot -p123.com


mysql>

注意:mysql是绝对不需要源码安装,所有的功能都是通过修改配置文件来实现。

####################

3.使用第三方扩展源安装php7.1
原版步骤:
#1.移除旧版php(之前有通过Base或epel库安装过php的,必须执行这个操作)

yum remove php-mysql-5.4 php php-fpm php-common

#2.安装扩展源

yum localinstall -y http://mirror.webtatic.com/yum/el7/webtatic-release.rpm

#3.安装php7.1版本

yum -y install php71w php71w-cli php71w-common php71w-devel \

php71w-embedded php71w-gd php71w-mcrypt php71w-mbstring php71w-pdo php71w-xml php71w-fpm
php71w-mysqlnd php71w-opcache php71w-pecl-memcached php71w-pecl-redis php71w-pecl-mongodb

实训步骤:
#1.将php71.tar.gz通过xshell传到服务器上

mkdir /soft

cd /soft

#2.解压缩

tar xf php71.tar.gz

#3.安装php7.1

yum install -y php7.1/*

#4.启动php-fpm管理进程, 并加入开机自启

systemctl start php-fpm

systemctl enable php-fpm

查看9000端口是否开启

ss -lntp | grep :9000

#################
验证Nginx是否能正常解析php动态请求,以及php程序能否正常连接数据库
1.创建一个测试站点

vim /etc/nginx/conf.d/www.conf

server {
server_name www.hs.com;
listen 80;

location / {
	root /code/www;
	index index.php index.html;
}

location ~ \.php$ {
    root /code/www;
    fastcgi_pass   127.0.0.1:9000;
    fastcgi_index  index.php;
    fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
    include        fastcgi_params;
}

}

2.新增info.php, 测试php解析是否工作正常

vim /code/www/test.php

<?php phpinfo(); ?>

3.测试php是否能连接mysql数据库服务[无论是本地数据库还是远程数据库,测试方式一致]

vim /code/www/mysql.php

<?php $servername = "localhost"; $username = "root"; $password = "123.com"; // 创建连接 $conn = mysqli_connect($servername, $username, $password); // 检测连接 if (!$conn) { die("Connection failed: " . mysqli_connect_error()); } echo "连接成功"; ?>

LNMP环境搭建
1.确认yum库可用,建议使用本地光盘实现

mount /dev/cdorm /mnt

rm -rf /etc/yum.repos.d/*

vim /etc/yum.repos.d/cdrom.repo

[cdrom]
name=cdrom repo
baseurl=file:///mnt
enabled=1
gpgcheck=0

yum repolist

2.创建/soft,存放实训所需所有软件

mkdir /soft

cd /soft

使用xshell或xftp将所有软件传至/soft目录下

3.安装LNMP软件

cd /soft

tar xf mysql56.tar.gz

tar xf php71.tar.gz

yum localinstall -y nginx-1.16.0-1.el7.ngx.x86_64.rpm mysql5.6/* php7.1/*

在这里插入图片描述

在这里插入图片描述

4.启动mysql

systemctl start mysqld

systemctl enable mysqld

5.修改mysql管理员root的密码

mysqladmin -u root password 123.com

6.启动php-fpm

systemctl start php-fpm

systemctl enable php-fpm

7.修改www站点配置文件,添加支持php

vim /etc/nginx/conf.d/www.conf

server {
server_name www.hs.com;
listen 80;

location / {
root /code/www;
index index.php index.html;
}

location ~ \.php$ {
    root /code/www;
    fastcgi_pass   127.0.0.1:9000;
    fastcgi_index  index.php;
    fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
    include        fastcgi_params;
}

}

在这里插入图片描述

8.重启nginx

systemctl restart nginx

9.创建测试页面,测试LNMP架构搭建成功

vim /code/www/test.php

<?php phpinfo(); ?>

vim /code/www/mysql.php

<?php $servername = "localhost"; $username = "root"; $password = "123.com"; // 创建连接 $conn = mysqli_connect($servername, $username, $password); // 检测连接 if (!$conn) { die("Connection failed: " . mysqli_connect_error()); } echo "连接成功"; ?>

10.客户端通过浏览器访问测试页面
http://www.hs.com/test.php
http://www.hs.com/mysql.php

在这里插入图片描述

在这里插入图片描述

LNMP应用二:博客
1.下载wordpress源码
2.解压缩源码

cd /soft

unzip wordpress-4.9.4-zh_CN.zip

3.将解压的目录中的所有内容拷贝或者剪切到指定站点目录下

cp -r wordpress/* /code/blog/

or

mv wordpress/* /code/blog/

4.创建所需数据库

mysql -uroot -p123.com

mysql> create database wordpress;
mysql> exit

5.修改权限
1)修改站点目录的所属,让nginx用户具有写权限(上传)

chown -R nginx /code/blog

2)修改php-fpm的程序用户为nginx

sed -i ‘s#apache#nginx#’ /etc/php-fpm.d/www.conf

6.修改blog的站点配置文件,添加支持php页面解析

vim /etc/nginx/conf.d/blog.conf

server {
……
location / {
root /code/blog;
index index.php index.html;
}

location ~ \.php$ {
    root /code/blog;
    fastcgi_pass   127.0.0.1:9000;
    fastcgi_index  index.php;
    fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
    include        fastcgi_params;
}

}

7.重启nginx和php-fpm

systemctl restart nginx php-fpm

8.通过浏览器访问http://bbs.hs.com,根据页面提示完成安装

修改权限
更改文件权限

更改php权限

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

wecenter的挂载步骤,大部分步骤与上面的blog相仿

在这里插入图片描述

更改目标的所有权限

在这里插入图片描述

实验结果

在这里插入图片描述

Linux
2019-11-30 21:49:02 FishLearning 阅读数 10
  • Linux系列之走进Linux新世界

    本课程为全新马哥Linux全套系列课程之一--Linux基础入门和架构了解,从Linux起源,Linux架构和Linux形成历史开始逐步讲解,让你彻彻底底了解Linux的诞生,之后介绍了Linux相关文化和核心组成结构,以及Linux常用命令和基本用法,课程由浅入深,讲授方法受到98%学员一致好评!

    20454 人正在学习 去看看 马永亮

Linux

1.Linux的引言

Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和Unix多用户多任务支持多线程和多CPU的操作系统。伴随着互联网的发展,Linux得到了来自全世界软件爱好者、组织、公司的支持。它除了在服务器操作系统方面保持着强劲的发展势头以外,在个人电脑、嵌入式系统上都有着长足的进步。目前Linux存在着许多不同的Linux发行版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、台式计算机。


2.Linux的诞生

​ 20世纪80年代,计算机硬件的性能不断提高,PC的市场不断扩大,当时可供计算机选用的操作系统主要有Unix、DOS和MacOS这几种。Unix价格昂贵,不能运行于PCDOS显得简陋,且源代码被软件厂商严格保密;

MacOS是一种专门用于苹果计算机的操作系统。此时,计算机科学领域迫切需要一个更加完善、强大、廉价和完全开放的操作系统。由于供教学使用的典型操作系统很少,因此当时在荷兰当教授的美国人AndrewS.Tanenbaum编写了一个操作系统,名为MINIX,为了向学生讲述操作系统内部工作原理。MINIX虽然很好,但只是一个用于教学目的的简单操作系统,而不是一个强有力的实用操作系统,然而最大的好处就是公开源代码。全世界学计算机的学生都通过钻研MINIX源代码来了解电脑里运行的MINIX操作系统,芬兰赫尔辛基大学大学二年级的学生Linus Torvalds就是其中一个,在吸收了MINIX精华的基础上,Linus于1991年写出了属于自己的Linux操作系统,版本为Linux0.01,是Linux时代开始的标志他利用Unix的核心,去除繁杂的核心程序,改写成适用于一般计算机的x86系统,并放在网络上供大家下载,1994年推出完整的核心Version1.0,至此,Linux逐渐成为功能完善、稳定的操作系统,并被广泛使用。

总结:Linux出现于1991年,是由芬兰赫尔辛基大学学生,Linus Torvalds和后来加入的众多爱好者共同开发完成。

在这里插入图片描述


3.Linux的特点

3.1 完全免费

​ Linux是一款免费的操作系统,用户可以通过网络或其他途径免费获得,并可以任意修改其源代码。这是其他的操作系统所做不到的。正是由于这一点,来自全世界的无数程序员参与了Linux的修改、编写工作,程序员可以根据自己的兴趣和灵感对其进行改变,这让Linux吸收了无数程序员的精华,不断壮大。

3.2 多用户、多任务

Linux支持多用户,各个用户对于自己的文件设备有自己特殊的权利,保证了各用户之间互不影响。多任务则是现在电脑最主要的一个特点,Linux可以使多个程序同时并独立地运行。同时``丰富的网络功能,可靠的系统安全,良好的可移植性,具有标准兼容性,出色的速度性能`。


4.Linux之Cent OS

4.1 centos 引言

CentOS(Community Enterprise Operating System,中文意思是社区企业操作系统)是Linux发行版之一,它是来自于Red Hat Enterprise Linux依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定性的服务器以CentOS替代商业版的[Red Hat](https://baike.baidu.com/item/Red Hat) Enterprise Linux使用。两者的不同,在于CentOS完全开源。

4.2 centos 和 readheat区别

目前的Linux操作系统主要应用于生产环境,主流企业的Linux系统仍旧是RedHat或者CentOS,他们出自于同样的源代码,但centos完全免费。其独有的yum命令支持在线升级,可以即时更新系统,不像RedHat 那样需要花钱购买支持服务!


5.安装 Cent OS

5.1 环境准备

# 环境要求:
		1. windows7+
		2. VMware Workstation8+,
		3. CentOS系统(镜像)

5.2 安装Cent OS

# 0.下载centos 

官网:https://www.centos.org/

官网的下载地址:http://isoredirect.centos.org/centos/7/isos/x86_64/

# 1.第一步:打开VMware Workstation

在这里插入图片描述

# 2.选择菜单File的第一项新建虚拟机

在这里插入图片描述

# 3.选择自定义虚拟机安装

在这里插入图片描述

# 4.选择下一步

在这里插入图片描述

# 5. 虚拟机设置之后安装系统

在这里插入图片描述

# 6.选择虚拟机安装系统以及版本

在这里插入图片描述

# 7.选择虚拟机名称与位置

在这里插入图片描述

# 8.设置处理器数

在这里插入图片描述

# 9.设置虚拟机内存

在这里插入图片描述

# 10.选择网络模式

在这里插入图片描述

# 11.选择io总线 下一步

在这里插入图片描述

# 12.选择新建硬盘

在这里插入图片描述

# 13.选择硬盘类型

在这里插入图片描述

# 14.拆分硬盘

在这里插入图片描述

# 15.设置磁盘位置

在这里插入图片描述

# 16.创建完成

在这里插入图片描述


6.Linux中目录结构

在这里插入图片描述

# 目录结构	
	bin  (binaries)存放二进制可执行文件																									 [重点]
	sbin  (super user binaries)存放二进制可执行文件,只有root才能访问
	etc (etcetera)存放系统配置文件																											[重点]
	usr  (unix shared resources)用于存放共享的系统资源  																	[重点]
	home 存放用户文件的根目录																														[重点]
	root  超级用户目录																															   [重点]
	dev (devices)用于存放设备文件
	lib  (library)存放跟文件系统中的程序运行所需要的共享库及内核模块
	mnt  (mount)系统管理员安装临时文件系统的安装点
	boot 存放用于系统引导时使用的各种文件
	tmp  (temporary)用于存放各种临时文件																							   [重点]
	var  (variable)用于存放运行时需要改变数据的文件


7. Linux中常用指令

# Linux中命令格式:
	
		命令  -选项  参数    如:  ls -l /usr 

注意:在linux中命令严格区分大小写

7.1 ls 命令

# ls  显示文件和目录列表	(list)
	常用参数:  
		-l (long)	 长格式显示文件和目录信息
		-a (all)	 显示所有文件和目录(包含隐藏文件和目录)
		-R         递归显示指定目录下的文件清单,即会显示指定目录分支内各子目录中的文件清单。

# 0. ls (查看目录下文件和目录)
[root@localhost ~]# ls
aa  aa.txt

# 1. ls -l (长格式展示文件)
[root@localhost ~]# ls -l
总用量 60
drwxrwxr-x      2   user1  user1    4096    Aug 17 09:10 abc
- rw- r-- r--    1   user1  user1    17     Aug 17 09:04 host.conf
- rw- r-- r--    1   user1  user1    38450  Aug 17 09:04 php.ini

`长格式含义:`
文件类型 文件权限   链接数  属主    属组    大小   日期   时间    文件名
d     rwxrwxr-x     2     user1  user1 4096  Aug 17 09:10  abc

# 2. ls -a (显示所有文件)
[root@localhost ~]# ls -a
.   aa      .bash_history  .bash_profile  .cshrc  .tcshrc
..  aa.txt  .bash_logout   .bashrc        .pki    .viminfo

# 3. ls -R (递归显示文件)
[root@localhost ~]# ls -R
.:
aa  aa.txt

./aa:

7.2 操作文件命令

# 0.cd 用来切换目录
# 1.pwd 显示当前工作目录(print working directory)
# 2.touch 创建空文件				                    
# 3.mkdir 创建目录(make directoriy)
			-p 父目录不存在情况下先生成父目录 (parents)            
# 4.cp 复制文件或目录(copy)
			-r 递归处理,将指定目录下的文件与子目录一并拷贝(recursive)     
# 5.mv 移动文件或目录、文件或目录改名(move)
			mv 文件名    新文件名      文件改名
			mv 文件名    目录名     	文件移动
			mv 目录名    不存在目录名  目录改名   
      mv 目录名	  已存在目录名  目录移动
# 6.rm 删除文件(remove)
			-r 同时删除该目录下的所有文件(recursive)
			-f 强制删除文件或目录(force)
# 7.rmdir 删除空目录(remove directoriy)
# 8.cat 显示文本文件内容 (catenate)
# 9.more、less 分页显示文本文件内容
# 10.head、tail查看文本中开头或结尾部分的内容
		head  -n  5  a.log 查看a.log文件的前5行
# 11.tail  -f  b.log 循环读取(fellow)
# 12.echo 输出命令
			echo   I love baby								说明:用来向屏幕输出一句话
			echo I Love baby  >>  aa.txt			说明:将这段内容输入到 文件中

7.3 网络相关命令

# 1.ip addr 查看IP地址

# 2.ping 测试网络连通性
		ping 192.168.0.1

7.4 tar命令

# tar命令
		-c 建立一个压缩文件的参数指令(create)
		-x 解开一个压缩文件的参数指令(extract)
		-z 是否需要用 gzip 压缩
		-v 压缩的过程中显示文件(verbose)
		-f 使用档名,在 f 之后要立即接档名(file)

`通常组合使用:`
			tar -cvf aaa.tar file1.txt file2.txt 					将file1和2打包成aaa.tar
			tar -zcvf aaa.tar.gz file1.txt file2.txt 			将file1和2打包成aaa.tar并压缩
			tar -zxvf aaa.tar.gz file1.txt file2.txt 			将aaa.tar.gz解压

7.5 systemctl 服务命令

# systemctl

	systemctl status 服务名          说明:查看某个服务的运行状态
	systemctl start 服务名 					说明:启动某个服务
	systemctl restart 服务名 				说明:重启某个服务
	systemctl stop 服务名 						说明:停止某个服务

7.6 进程相关命令

# 1.ps 询在当前控制台上运行的进程
		ps  -aux   说明:查询系统中所有运行的进程,包括后台进程,其中参数a是所有进程,参数x包括不占用控制台的进程,参数u显示用户。
		ps  -ef		 说明:查询系统中所有运行的进程,包括后台进程,而且可以显示出每个进程的父进程号。

# 2.top	命令  动态显示系统进程

# 3.kill 杀死进程
		kill  3029 说明:上述命令中3029是进程号;一般在执行kill命令之前,先用ps或pstree来查询一下将要被杀掉的进程的进程号。 
		kill  -9  3029 说明:强制终止3029号进程的运行,其中参数-9代表强制的意思,实际上kill命令是向该进程发送信号,
												该进程接到信号后决定是否停止运行,有些守护进程必须要收到参数9才终止运行。
		

7.7 vi命令

# vi / vim是Unix / Linux上最常用的文本编辑器而且功能非常强大。

在这里插入图片描述

# 常用命令:

		i						在光标前插入
 		I						在光标当前行开始插入
 		a						在光标后插入
 		A						在光标当前行末尾插入
 		o						在光标当前行的下一行插入新行
 		O						在光标当前行的上一行插入新行
 		----------------重点---------------------------
 		:set nu			显示行号
 		:set nonu		取消行号
 		gg					到文本的第一行
 		G						到文本的最后一行
 		:n					到文本的第n行
 		------------------重点-------------------------
 		u						undo,取消上一步操作
 		Ctrl + r		redo,返回到undo之前
 		-------------------重点------------------------
 		Shift+ zz		保存退出,与“:wq”作用相同
		:q					退出不保存
		:q!					强制退出不保存
		:wq					保存退出
		:wq!				强制保存退出

7.8 软件相关命令

RPM命令

RPM是RedHat Package Manager(RedHat软件包管理工具)的缩写,这一文件格式名称虽然打上了RedHat的标志,但是其原始设计理念是开放式的,现在包括RedHat、CentOS、SUSE等Linux的分发版本都有采用,可以算是公认的行业标准了。RPM文件在Linux系统中的安装最为简便,

# rpm 命令  
	常用参数:
      i:安装应用程序(install)
      e:卸载应用程序(erase)
      vh:显示安装进度;(verbose   hash) 
      U:升级软件包;(update) 
      qa: 显示所有已安装软件包(query all)
	例子:rmp  -ivh  gcc-c++-4.4.7-3.el6.x86_64.rpm

YUM命令

Yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE、CentOS中的Shell前端软件包管理器。基於RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软件包,无须繁琐地一次次下载、安装。

例子:
    yum  install  gcc-c++
    yum  remove   gcc-c++
    yum  update   gcc-c++

使用YUM命令必须连接外部网络

7.9 用户和组相关命令

# 1.查看当前用户:whoami
# 2.查看登录用户:who
	-m或am I	只显示运行who命令的用户名、登录终端和登录时间
	-q或--count	只显示用户的登录账号和登录用户的数量
# 3.退出用户:		exit
# 4.添加、删除组账号:groupadd、groupdel
# 5.添加用户账号:useradd
		-g	指定组名称  说明:如果创建用户的时候,不指定组名,那么系统会自动创建一个和用户名一样的组名。
# 6.设置用户密码:passwd [用户名]
# 7.su 切换用户
		su  root 

7.10 权限相关命令

Linux文件有三种典型的权限,即r读权限、w写权限和x执行权限。在长格式输出中在文件类型的后面有9列权限位,实际上这是针对不同用户而设定的。r=4,w=2,x=1

# chmod
	字母法:chmod u/g/o/a +/-/= rwx 文件
	
    [ u/g/o/a ]	含义
    	u	user 					表示该文件的所有者
    	g	group 				表示与该文件的所有者属于同一组( group )者,即用户组
    	o	other 				表示其他以外的人
    	a	all 					表示这三者皆是

    [ +-= ]	含义
    	+								增加权限
    	-								撤销权限
    	=								设定权限

    rwx	含义
    	r								read 表示可读取,对于一个目录,如果没有r权限,那么就意味着不能通过ls查看这个目录的内容。
    	w								write 表示可写入,对于一个目录,如果没有w权限,那么就意味着不能在目录下创建新的文件。
    	x								excute 表示可执行,对于一个目录,如果没有x权限,那么就意味着不能通过cd进入这个目录。

8.CRT终端操作

# 0.准备工作
		安装CRT客户端工具,安装winscp工具

# 1.设置linux获取ip地址 (编辑网络配置文件)	
		vi /etc/sysconfig/network-scripts/ifcfg-ens33

# 2.修改ens33配置文件:
    BOOTPROTO=dhcp
    ONBOOT=yes

# 3.重启启动网路服务加载修改配置生效
		systemctl restart network

# 4.查看ip地址
		ip addr

# 5.此时ip已经获取
		ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
    link/ether 00:0c:29:07:16:9e brd ff:ff:ff:ff:ff:ff
    inet 192.168.202.136/24 brd 192.168.202.255 scope global noprefixroute dynamic ens33
       valid_lft 1459sec preferred_lft 1459sec
    inet6 fe80::b22b:7e01:db87:52fe/64 scope link noprefixroute 

# 6.测试外部网络连通(保证宿主机windows可以上网前提)
		ping www.baidu.com

# 7.使用CRT工具连接即可

9.安装JDK

9.1 下载jdk

# 1.下载jdk
	https://www.oracle.com/technetwork/java/javase/downloads/index.html

# 2.通过CRT|WinSCP工具将jdk上传到linux系统中	

在这里插入图片描述

9.2 tar包安装

# 1.将JDK解压缩到指定目录
	tar -zxvf jdk-8u171-linux-x64.tar.gz -C /usr/
	注意:-C参数是将JDK解压之后文件放入usr目录中

# 2.进入jdk解压缩目录查看
	cd /usr/jdk1.8.0_171/

# 3.查看详细信息
	[root@localhost jdk1.8.0_171]# ls
		bin        db       javafx-src.zip  lib      man          release  THIRDPARTYLICENSEREADME-JAVAFX.txt
		COPYRIGHT  include  jre             LICENSE  README.html  src.zip  THIRDPARTYLICENSEREADME.txt

# 4.配置环境变量
	 vi /etc/profile
	 
# 5.在文件末尾加入如下配置
	export JAVA_HOME=/usr/jdk1.8.0_171
	export PATH=$PATH:$JAVA_HOME/bin

# 6.加载配置生效
	source /etc/profile    加载配置生效
	reboot                 重启系统
	注意: 以上两个选项选择任意一个即可source可以不用重启立即生效,某些情况下source无法生效时,可以使用重启试试

# 7.测试环境变量
	java
	javac
	java -version

9.3 rpm包安装

# 1.安装jdk
	[root@localhost ~]# rpm -ivh jdk-8u171-linux-x64.rpm 
		准备中...                          ################################# [100%]
		正在升级/安装...
   		1:jdk1.8-2000:1.8.0_171-fcs        ################################# [100%]
			Unpacking JAR files...
        tools.jar...
        plugin.jar...
        javaws.jar...
        deploy.jar...
        rt.jar...
        jsse.jar...
        charsets.jar...
        localedata.jar...

# 2.搜索默认安装位置
	 [root@localhost ~]# find / -name "java"
	 	/usr/java/jdk1.8.0_171-amd64/bin/java
		/usr/java/jdk1.8.0_171-amd64/jre/bin/java

# 3.配置环境变量
	 vi /etc/profile

# 4.在文件末尾加入如下配置
	export JAVA_HOME=/usr/java/jdk1.8.0_171-amd64/
	export PATH=$PATH:$JAVA_HOME/bin

# 5.加载配置生效
	source /etc/profile    加载配置生效
	reboot                 重启系统
	注意: 以上两个选项选择任意一个即可source可以不用重启立即生效,某些情况下source无法生效时,可以使用重启试试

# 6.测试环境变量
	java
	javac
	java -version
	

10.安装Tomcat

# 0.下载tomcat
	http://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-8/v8.5.46/bin/apache-tomcat-8.5.46.tar.gz

# 1.通过工具上传到Linux系统中

# 2.解压缩到/usr目录中
	[root@localhost ~]# tar -zxvf apache-tomcat-8.5.46.tar.gz -C /usr/

# 3.查看解压内容
	[root@localhost apache-tomcat-8.5.46]# ls -l
    总用量 124
    drwxr-x---. 2 root root  4096 10月 13 12:27 bin
    -rw-r-----. 1 root root 19318 9月  17 02:19 BUILDING.txt
    drwx------. 2 root root   238 9月  17 02:19 conf
    -rw-r-----. 1 root root  5407 9月  17 02:19 CONTRIBUTING.md
    drwxr-x---. 2 root root  4096 10月 13 12:27 lib
    -rw-r-----. 1 root root 57011 9月  17 02:19 LICENSE
    drwxr-x---. 2 root root     6 9月  17 02:17 logs
    -rw-r-----. 1 root root  1726 9月  17 02:19 NOTICE
    -rw-r-----. 1 root root  3255 9月  17 02:19 README.md
    -rw-r-----. 1 root root  7139 9月  17 02:19 RELEASE-NOTES
    -rw-r-----. 1 root root 16262 9月  17 02:19 RUNNING.txt
    drwxr-x---. 2 root root    30 10月 13 12:27 temp
    drwxr-x---. 7 root root    81 9月  17 02:17 webapps
    drwxr-x---. 2 root root     6 9月  17 02:17 work

# 4.启动tomcat
	[root@localhost apache-tomcat-8.5.46]# ./bin/startup.sh 

# 5.关闭网络防火墙
	systemctl stop firewalld	   关闭网络防火墙
	systemctl disable firewalld  关闭开启自启动(永久关闭)

# 6.在windows中访问tomcat
	http://10.15.0.8:8080/

# 7.显示tomcat实时控制台信息
	进入tomcat的logs目录中使用tail -f catalina.out 命令实时查看控制台信息 

# 8.关闭tomcat
	在tomcat的bin目录下面使用 ./shutdown.sh

11.安装MySQL

11.1 环境准备

# 1.卸载mariadb,否则安装mysql会出现冲突
# 2.执行命令rpm -qa | grep mariadb
# 3.列出所有被安装的mariadb rpm 包;
# 4.执行命令rpm -e --nodeps mariadb-libs-5.5.56-2.el7.x86_64

11.2 本地安装

# 0.上传下载好的软件包到系统中

在这里插入图片描述

# 0.执行本地安装包之前必须先安装vim
	yum install -y vim
# 1.安装步骤
	rpm -ivh perl-*
	rpm -ivh net-tools-2.0-0.22.20131004git.el7.x86_64.rpm
	rpm -ivh mysql-community-common-5.6.42-2.el7.x86_64.rpm
	rpm -ivh mysql-community-libs-5.6.42-2.el7.x86_64.rpm
	rpm -ivh mysql-community-client-5.6.42-2.el7.x86_64.rpm
	rpm -ivh mysql-community-server-5.6.42-2.el7.x86_64.rpm

11.3 在线安装

# 1.添加官方的yum源创建并编辑mysql-community.repo文件
		vi /etc/yum.repos.d/mysql-community.repo
# 2.粘贴以下内容到源文件中
		[mysql56-community]
    name=MySQL 5.6 Community Server
    baseurl=http://repo.mysql.com/yum/mysql-5.6-community/el/7/$basearch/
    enabled=1
    gpgcheck=0
    gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql
    
    注意:如果需要安装mysql5.7只需要将baseurl修改即可 
    		baseurl=http://repo.mysql.com/yum/mysql-5.7-community/el/7/$basearch/

# 3.安装mysql
	sudo yum install mysql-community-server

11.4 设置root用户密码

# 1.启动mysql数据库
	[root@localhost mysql]# systemctl start mysqld

# 2.修改mysql数据库密码
	mysqladmin -u root -p password 回车 输入原始密码 在输入新的密码
	
	注意:5.7之前版本安装完成之后没有密码,mysql5.7之后的版本的初始密码是随机生成的,放在了 /var/log/mysqld.log
			使用命令 grep ‘temporary password’ /var/log/mysqld.log 读出来即可
# 3.登录mysql
	[root@localhost mysql]# mysql -u root -p

11.5 开启远程访问

# 1.安装完成mysql时,发现mysql数据库,不允许我们远程连接需要修改设置

在这里插入图片描述

# 2.登录mysql,并选择使用mysql数据库

在这里插入图片描述

# 3.查看mysql库中的所有表

在这里插入图片描述

# 4.查询user表

在这里插入图片描述

# 5.执行如下命令
	grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;

在这里插入图片描述

# 6.刷新权限
	flush privileges;

在这里插入图片描述

# 7.重启服务
	systemctl restart mysqld
# 8.测试连接

在这里插入图片描述


12.MySQL主从复制

# 1.修改mysql的配置文件
	[root@localhost mysql]# vim /etc/my.cnf

# 2.分别在配置文件中加入如下配置

	mysql(master):
		server-id=1
		log-bin=mysql-bin
		log-slave-updates
		slave-skip-errors=all
	
	msyql(slave):
		server-id=2
		log-bin=mysql-bin
		log-slave-updates
		slave-skip-errors=all
		
		注意:两个机器的server-id不能一致

在这里插入图片描述

# 3.重启mysql服务
	systemctl restart mysqld

# 4.登录mysql执行如下命令检测配置是否生效
	SHOW VARIABLES like 'server_id';

在这里插入图片描述

# 5.登录master节点执行如下命令
		show master status;

在这里插入图片描述

# 6.登录从节点执行如下命令:
		change master to 
		master_host='10.15.0.9',
		master_user='root',
		master_password='root',
		master_log_file='mysql-bin.000001',
		master_log_pos=120;

在这里插入图片描述

# 7.开启从节点
		start slave;

在这里插入图片描述

# 8.查看从节点状态
		************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 10.15.0.9
                  Master_User: root
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000001
          Read_Master_Log_Pos: 120
               Relay_Log_File: mysqld-relay-bin.000002
                Relay_Log_Pos: 283
        Relay_Master_Log_File: mysql-bin.000001
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
   	
    注意:
    		1.出现 Slave_IO_Running: Yes 和 Slave_SQL_Running: Yes 说名成功,
    		2.如果在搭建过程出现错误,可以查看查看错误日志文件 cat /var/log/mysqld.log

# 9.通过客户端工具进行测试
	
# 10.关闭主从复制(在从节点执行)
	stop slave;

注意:如果出现Slave I/O: Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work. Error_code: 1593错误,请执行如下命令,rm -rf /var/lib/mysql/auto.cnf删除这个文件,之所以出现会出现这样的问题,是因为我的从库主机是克隆的主库所在的主机,所以auto.cnf文件中保存的UUID会出现重复.


13.读写分离

13.1 MyCat引言

基于阿里开源的Cobar产品而研发,Cobar的稳定性、可靠性、优秀的架构和性能以及众多成熟的使用案例使得MYCAT一开始就拥有一个很好的起点,站在巨人的肩膀上,我们能看到更远。业界优秀的开源项目和创新思路被广泛融入到MYCAT的基因中,使得MYCAT在很多方面都领先于目前其他一些同类的开源项目,甚至超越某些商业产品。

MYCAT背后有一支强大的技术团队,其参与者都是5年以上资深软件工程师、架构师、DBA等,优秀的技术团队保证了MYCAT的产品质量。MYCAT并不依托于任何一个商业公司,因此不像某些开源项目,将一些重要的特性封闭在其商业产品中,使得开源项目成了一个摆设.

13.2 安装Mycat

# 1.下载mycat
	http://dl.mycat.io/1.6-RELEASE/Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz

# 2.解压mycat
	tar -zxvf Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz

在这里插入图片描述

# 3.查看解压之后目录]
	[root@localhost mycat]# ls
	总用量 12
	drwxr-xr-x. 2 root root  190 10月 14 22:58 bin
	drwxrwxrwx. 2 root root    6 3月   1 2016 catlet
	drwxrwxrwx. 4 root root 4096 10月 14 22:58 conf
	drwxr-xr-x. 2 root root 4096 10月 14 22:58 lib
	drwxrwxrwx. 2 root root    6 10月 28 2016 logs
	-rwxrwxrwx. 1 root root  217 10月 28 2016 version.txt

在这里插入图片描述

# 4.移动到/usr目录
	mv mycat/ /usr/

# 5.配置mycat中conf下的配置schema.xml
	<!-- 定义MyCat的逻辑库  -->   
    <schema name="test_schema" checkSQLschema="false" sqlMaxLimit="100" dataNode="testNode"></schema>
    <!-- 定义MyCat的数据节点 -->
    <dataNode name="testNode" dataHost="dtHost" database="test" />
   <dataHost name="dtHost" maxCon="1000" minCon="10" balance="1"
                writeType="0" dbType="mysql" dbDriver="native" switchType="-1"  slaveThreshold="100">
                <heartbeat>select user()</heartbeat>
                <!--写节点-->
                <writeHost host="hostM1" url="192.168.28.128:3306" user="root"
                        password="root">
                  		<!--从节点-->
                			<readHost host="hostS1" url="192.168.28.129:3306" user="root" password="root" />
                </writeHost>
   </dataHost>
# 6.配置登陆mycat的权限server.xml
			<system>
                <!-- 这里配置的都是一些系统属性,可以自己查看mycat文-->
                <property name="defaultSqlParser">druidparser</property>
                <property name="charset">utf8mb4</property>
        	</system>

			<user name="root">
                <property name="password">root</property>
                <property name="schemas">test_schema</property>
        	</user>
# 7.启动mycat
	 mycat console

# 8.查看日志
	tail -f ../logs/mycat.log

# 9.数据库连接配置,测试

14.安装Nginx

14.1 Nginx的引言

Nginx是一款轻量级Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。由俄罗斯的程序设计师Igor Sysoev所开发,供俄国大型的入口网站及搜索引擎Rambler(俄文:Рамблер)使用。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:京东新浪网易腾讯淘宝等。

14.2 Nginx的安装

# 0.安装必要依赖
	yum install -y gcc pcre-devel zlib-devel
# 1.下载Nginx
	http://nginx.org/en/download.html

# 2.将Nginx上传到linux中,并解压缩
	 tar -zxvf nginx-1.11.1

# 3.查看Nginx安装目录
	[root@localhost nginx-1.11.1]# ls
	auto  CHANGES  CHANGES.ru  conf  configure  contrib  html  LICENSE  man  README  src

# 4.在Nginx安装目录中执行如下命令:(指定安装位置)
	./configure  --prefix=/usr/nginx

# 5.执行上述命令后,执行如下命令:
	make && make install

# 6.编译完成后进入编译安装目录/usr/nginx目录中查看:
	[root@localhost nginx]# ls -l
	总用量 4
	drwxr-xr-x. 2 root root 4096 10月 14 21:17 conf
	drwxr-xr-x. 2 root root   40 10月 14 21:17 html
	drwxr-xr-x. 2 root root    6 10月 14 21:17 logs
	drwxr-xr-x. 2 root root   19 10月 14 21:17 sbin

# 7.启动nginx,进入nginx安装目录的sbin目录中执行:
	./nginx   

# 8.在windows中浏览器访问,可以看到nginx欢迎页面:
	http://10.15.0.8:80/
	
		注意:关闭网络防火墙

# 9.关闭nginx,进入nginx安装目录的sbin目录中执行:
	./nginx -s stop

# 10.nginx配置文件在nginx安装目录的conf目录中:
	[root@localhost conf]# ls -l
	总用量 60
	-rw-r--r--. 1 root root 2656 10月 14 21:17 nginx.conf
	.......
	注意:nginx.conf为nginx的配置文件,可以在nginx.conf修改nginx默认配置

15.Tomcat负载均衡集群

# 0.准备多个tomcat
	 tar -zxvf apache-tomcat-8.5.46.tar.gz #解压缩一个新的tomcat安装包
	 mv apache-tomcat-8.5.46 tomcat1 			 #将名称改为tomcat1
	 cp -r tomcat1/ tomcat2								 #复制一份
	 cp -r tomcat1/ tomcat3                #复制一份

# 1.此时当前目录中有三个服务器,如下:
	[root@localhost ~]# ls -l
	总用量 12248
	-rwxrwxrwx. 1 root root  11623939 10月 13 12:25 apache-tomcat-8.5.46.tar.gz
	drwxr-xr-x. 9 root root       220 10月 14 21:28 tomcat1
	drwxr-xr-x. 9 root root       220 10月 14 21:38 tomcat2
	drwxr-xr-x. 9 root root       220 10月 14 21:38 tomcat3
# 2.修改tomcat1端口号:(伪分布式)
		vim tomcat1/conf/server.xml,命令修改如下内容:
		a.<Server port="8001" shutdown="SHUTDOWN">
		b.<Connector port="8888" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
   	c.<Connector port="10010" protocol="AJP/1.3" redirectPort="8443" />
# 3.修改tomcat2端口号:(伪分布式)
		vim tomcat2/conf/server.xml,命令修改如下内容:
  	a.<Server port="8002" shutdown="SHUTDOWN">
		b.<Connector port="8889" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
   	c.<Connector port="10011" protocol="AJP/1.3" redirectPort="8443" />
# 4.修改tomcat3端口号:(伪分布式)
		vim tomcat2/conf/server.xml,命令修改如下内容:
  	a.<Server port="8003" shutdown="SHUTDOWN">
		b.<Connector port="8890" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
   	c.<Connector port="10012" protocol="AJP/1.3" redirectPort="8443" />
# 5.将多个tomcat启动:
		tomcat1/bin/startup.sh 
		tomcat2/bin/startup.sh 
		tomcat3/bin/startup.sh
    
# 6.查看tomcat是否启动成功
		ps -aux|grep tomcat

在这里插入图片描述

# 7.在windows中分别访问tomcat,都看到主页代表启动成功:
	
	http://10.15.0.8:8888/
	http://10.15.0.8:8889/
	http://10.15.0.8:8890/
	
	注意:这步一定要关闭网路防火墙
# 8.将多个tomcat配置到nginx的配置文件中:
	1).在server标签上加入如下配置:
    upstream tomcat-servers {
      server 10.15.0.8:8888;
      server 10.15.0.8:8889;
      server 10.15.0.8:8890;
    }
	2).将配置文件中 location /替换为如下配置:
		location / {
			 proxy_pass http://tomcat-servers;
			 proxy_redirect    off;
			 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
			 proxy_set_header X-Real-IP $remote_addr;
			 proxy_set_header Host $http_host;
			 proxy_next_upstream http_502 http_504 error timeout invalid_header;
		   }

在这里插入图片描述

# 9.进入nginx安装目录sbin目录启动nginx
	./nginx -c /usr/nginx/conf/nginx.conf
# 10.访问nginx,看到其中一个tomcat画面:
	http://10.15.0.8/ 

在这里插入图片描述

15.1Nginx负载均衡策略

# 1.轮询
	 说明: 默认策略,每个请求会按时间顺序逐一分配到不同的后端服务器

# 2.weight 权重
		说明: weight参数用于指定轮询几率,weight的默认值为1,;weight的数值与访问比率成正比
    upstream tomcat-servers {
        server localhost:8080   weight=2;  
        server localhost:8081;  
        server localhost:8082   backup;  
    }
    注意:1.权重越高分配到需要处理的请求越多。2.此策略可以与least_conn和ip_hash结合使用

# 3.ip_hash
	 说明:指定负载均衡器按照基于客户端IP的分配方式,这个方法确保了相同的客户端的请求一直发送到相同的服务器,以保证session会话。这样每个访
	 			客都固定访问一个后端服务器,可以解决session不能跨服务器的问题。
	 upstream tomcat-servers {
        ip_hash;    #保证每个访客固定访问一个后端服务器
        server localhost:8080;
        ......
    }

# 4.least_conn
	说明: 把请求转发给连接数较少的后端服务器。轮询算法是把请求平均的转发给各个后端,使它们的负载大致相同;但是,有些请求占用的时间很长,会导致其所在的后端负载较高。这种情况下,least_conn这种方式就可以达到更好的负载均衡效果。
		 upstream tomcat-servers{
        least_conn;    #把请求转发给连接数较少的后端服务器
        server localhost:8080;
    }

16.MSM配置

Memcached Session Manager基于memcache缓存的session共享.即使用cacheDB存取session信息,应用服务器接受新请求将session信息保存在cache DB中,当应用服务器发生故障时,调度器会遍历寻找可用节点,分发请求,当应用服务器发现session不在本机内存时,则去cacheDB中查找,如果找到则复制到本机,这样实现session共享和高可用

# 1.安装memcached
	 yum install -y memcached

# 2.启动memcached
	memcached -p 11211 -vvv -u root

# 3.tomcat安装的lib目录中放入与memcache整合jar包
		cp *.jar tomcat1/lib
		cp *.jar tomcat2/lib
		cp *.jar tomcat3/lib

# 4.配置tomcat目录中conf目录中context.xml(所有tomcat均需要配置)
	<Context>
    <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
        memcachedNodes="n1:10.15.0.8:11211"
        requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
        sticky="false"
        sessionBackupTimeout="false"
          transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"
        />
	</Context>

# 5.放入测试项目进行测试

tomcat熵池阻塞问题

在JVM环境中解—一劳永逸

打开$JAVA_PATH/jre/lib/security/java.security这个文件,找到下面的内容:

securerandom.source=file:/dev/urandom大概在70行 ,替换成

securerandom.source=file:/dev/./urandom
2011-01-05 19:16:08 saram 阅读数 0
  • Linux系列之走进Linux新世界

    本课程为全新马哥Linux全套系列课程之一--Linux基础入门和架构了解,从Linux起源,Linux架构和Linux形成历史开始逐步讲解,让你彻彻底底了解Linux的诞生,之后介绍了Linux相关文化和核心组成结构,以及Linux常用命令和基本用法,课程由浅入深,讲授方法受到98%学员一致好评!

    20454 人正在学习 去看看 马永亮

        出于对Linux的喜爱,专门做了一个Linux网址导航网站--Linux265,目的就是为了帮助Linux用户更好的进行学习与交流,便于平时查找Linux相关资料使用。由于个人能力有限,目前网站刚刚初成,还很不完善,当前网站收集的Linux相关信息还比较少。为推动Linux在中国的发展,也为让更多的人学习Linux的时候更加方便找到相关资料,浏览相关Linux网站,希望大家能支持帮助该网站的发展,不断的完善网站收集内容,使他能够为更多的人提供帮助。

 如果你喜欢Linux265导航网站,那么请告诉你身边喜欢Linux的朋友,也许对他也有帮助。


 谢谢各位朋友对Linux265的支持。

 http://www.linux265.com

如果您也有自己的空间站点,乐意给Linux265做个友链,在这里也非常感谢您对Linux265的帮助。

2017-09-10 21:34:10 liyuerge 阅读数 178
  • Linux系列之走进Linux新世界

    本课程为全新马哥Linux全套系列课程之一--Linux基础入门和架构了解,从Linux起源,Linux架构和Linux形成历史开始逐步讲解,让你彻彻底底了解Linux的诞生,之后介绍了Linux相关文化和核心组成结构,以及Linux常用命令和基本用法,课程由浅入深,讲授方法受到98%学员一致好评!

    20454 人正在学习 去看看 马永亮


  使用linux的场景:移动设备,企业应用,通信基础设施,数据中心,超级计算机等方面占据着统治地位,智能家居等方面也有很大的份额,例如:安卓的内核是linux,平板电视,超级计算机(天河二号),各大网站的服务器等等。
  linux是互联网基石之一,不是属于某一个人,并且是一个free software,
  free是指自由,分享,互惠的精神,linux系统的代码是开放的,可以被任何人获取使用使用,修改,定制,重新发布
  谁创造力linux呢?
  必须提到两个人,Linus Torvalds:公认的linux之父,linux的内核由其编写;Richard Stallman :自由软件之父,是自由软件运动的发起人,开发了很多linux的基础应用。
  minix系统
  Linus想仿照minix系统开发一个用在自己的电脑上的开源系统,于是开发出linux0.0.1,只有内核。而Richard发起了易友软件运动,建立了gnu
  两只结合,形成了GNU/linux
  linux由全球开发者,非营利性基金,相关公司,社区组织,和linux爱好者共同开发,是世界上最大的合作开源项目,平均2-3个月就会更新一个内核版本,
  随着内核的版本的迭代,各个公司组织,都推出了自己 发行版本(Distributions),各发行版本不同之处不在于内核,主要表现在各自外部程序,安全性,可用性等方面不同,例如,有的专注提供良好桌面环境,有的专注于开发工作站,有的稳定性,安全性非常好,用作网络服务器操作系统,目前叫得上号的发行版有数百个,适用于服务器工作站的系统有五个:ubuntu,debian,centos,opensuse,redhat

2011-09-25 23:29:30 hnhbdss 阅读数 428
  • Linux系列之走进Linux新世界

    本课程为全新马哥Linux全套系列课程之一--Linux基础入门和架构了解,从Linux起源,Linux架构和Linux形成历史开始逐步讲解,让你彻彻底底了解Linux的诞生,之后介绍了Linux相关文化和核心组成结构,以及Linux常用命令和基本用法,课程由浅入深,讲授方法受到98%学员一致好评!

    20454 人正在学习 去看看 马永亮
http://lamp.linux.gov.cn/jinbuguo_florilegium.html

Linux学习笔记

阅读数 24

没有更多推荐了,返回首页