java是一种跨平台的、面向对象的程序设计语言,Java 技术具有卓越的通用性、高效性、平台移植性和安全性
Java SE (标准版)
Java EE (企业版)
JDK是Sun针对Java开发者推出的Java语言的软件开发工具包
JDK是整个Java的核心,包括了Java运行环境和Java工具(如编译、排错、打包等工具)以及Java基础的类库
JRE是JDK的子集,包括
Servlet是java扩展Web服务器功能的组件规范
常见Servlet容器
要求部署Tomcat服务器,具体要求如下:
然后客户机访问此Web服务器验证效果:
使用2台虚拟机,其中一台作为Tomcat服务器(192.168.99.100)、另外一台作为测试用的Linux客户机(192.168.99.5)
使用RPM安装JDK基础环境
使用源码安装部署Tomcat服务器
步骤一:部署Tomcat服务器软件
1)使用RPM安装JDK环境
- [root@web1 ~]# yum -y install java-1.8.0-openjdk #安装JDK
- [root@web1 ~]# java -version #查看JAVA版本
2)安装Tomcat
- [root@web1 lnmp_soft]# tar -xf apache-tomcat-8.0.30.tar.gz
- [root@web1 lnmp_soft]# mv apache-tomcat-8.0.30 /usr/local/tomcat
- [root@web1 lnmp_soft]# ls /usr/local/tomcat
- bin/ #主程序目录
- webapps/ #页面目录
- conf/ #配置文件目录
- logs/ #日志目录
- temp/ #临时目录
- work/ #自动编译目录
- lib/ #库文件目录
3)启动服务
[root@web1 ~]# /usr/local/tomcat/bin/startup.sh
4)服务器验证端口信息
- [root@web1 ~]# ss -nutlp |grep java #查看java监听的端口
- tcp 0 0 :::8080 :::* LISTEN 2778/java
- tcp 0 0 :::8009 :::* LISTEN 2778/java
- tcp 0 0 ::ffff:127.0.0.1:8005 :::* LISTEN 2778/java
提示:如果检查端口时,8005端口启动非常慢,默认tomcat启动需要从/dev/random读取大量的随机数据,默认该设备生成随机数据的速度很慢,可用使用下面的命令用urandom替换random。
- [root@web1 ~]# mv /dev/random /dev/random.bak
- [root@web1 ~]# ln -s /dev/urandom /dev/random
- [root@web1 ~]# killall java
- [root@web1 ~]# cd /usr/local/tomcat
- [root@web1 tomcat]# bin/startup.sh
- [root@web1 ~]# ss -nutlp |grep java
另外,还可以使用方案二解决:
- [root@web1 ~]# yum install rng-tools
- [root@web1 ~]# systemctl start rngd
- [root@web1 ~]# systemctl enable rngd
5)客户端浏览测试页面
http://192.168.99.100:8080
步骤二:修改Tomcat配置文件
1)创建静态页面
[root@web1 tomcat]# echo "tomcat-test~~~~" > webapps/ROOT/test01.html
浏览器访问http://192.168.99.100:8080/test01.html
2)测试JSP页面
- [root@web1 ~]# vim /usr/local/tomcat/webapps/ROOT/test02.jsp
- <html>
- <body>
- <center>
- Now time is: <%=new java.util.Date()%>
- </center>
- </body>
- </html>
浏览器访问http://192.168.99.100:8080/test02.jsp
使用Tomcat部署加密虚拟主机,实现以下要求:
修改server.xml配置文件,创建www.b.com虚拟主机,顺便修改原有虚拟主机为www.a.com
1)修改server.xml配置文件,创建虚拟主机
- [root@web1 ~]# vim /usr/local/tomcat/conf/server.xml
- ...
- <Host name="www.b.com" appBase="web_b">
- </Host>
- <Host name="www.a.com" appBase="webapps" unpackWARS="true" autoDeploy="true">
- ...
- ...
- </Host>
2)创建虚拟主机对应的页面根路径并测试
- [root@web1 tomcat]# mkdir -p web_b/ROOT #之后创建b网站的目录
- [root@web1 tomcat]# echo "tomcat-A~~~" > webapps/ROOT/index.html
- [root@web1 tomcat]# echo "tomcat-B~~~" > web_b/ROOT/index.html
- tail -1 /etc/hosts #查看域名解析
- 192.168.99.100 www.a.com www.b.com
- [root@web1 tomcat]# bin/shutdown.sh #关闭tomcat
- [root@web1 tomcat]# bin/startup.sh #开启
- [root@web1 tomcat]# curl www.a.com:8080 #测试
- tomcat-A~~~
- [root@web1 tomcat]# curl www.b.com:8080
- tomcat-B~~~
3)查看虚拟主机www.a.com的配置
unpackWARs="true" # 自动解war包
autoDeploy="true" # 自动更新开发工程师编写的网站功能
- [root@proxy tomcat]# yum -y install java-1.8.0-openjdk-devel # 安装可以制作war包的工具
- [root@proxy tomcat]# jar -cf a.war /var/log # 之后可以使用jar命令打war包
- [root@proxy tomcat]# cp a.war webapps # 将war包放入虚拟主机的网页目录
- [root@proxy tomcat]# ls webapps #检查,可以看到已经自动解开,如果无效可以尝试重启tomcat
1)测试1
- [root@web1 ~]# vim /usr/local/tomcat/conf/server.xml
- ...
- <Host name="www.b.com" appBase="web_b">
- <Context path="" docBase="" />
- </Host>
- ...
- echo "web_b/ROOT/index.html" > web_b/ROOT/index.html #默认页面路径
- echo "web_b/index.html" > web_b/index.html #创建素材,定义新路径
- curl www.b.com:8080 #测试可以看到的是默认的页面路径
- web_b/ROOT/index.html
- 之后重启tomcat
- curl www.b.com:8080 #重启后测试可以看到新路径
- web_b/index.html
2)测试2
- [root@web1 ~]# vim /usr/local/tomcat/conf/server.xml
- ...
- <Host name="www.b.com" appBase="web_b">
- <Context path="" docBase="abc" /> #修改成abc
- </Host>
- ...
- mkdir web_b/abc #创建测试目录
- echo "web_b/abc/index.html" > web_b/abc/index.html #测试页面
- 重启tomcat
- [root@proxy tomcat]# curl www.b.com:8080 #查看,见到新路径
- web_b/abc/index.html
3)测试3
- [root@web1 ~]# vim /usr/local/tomcat/conf/server.xml
- ...
- <Host name="www.b.com" appBase="web_b">
- <Context path="" docBase="/abc" /> #修改成/abc
- </Host>
- ...
- mkdir /abc #创建测试目录
- echo "/abc/index.html" > /abc/index.html #创建测试文件
- 重启tomcat
- [root@proxy tomcat]# curl www.b.com:8080 #得到新路径
- /abc/index.html
4)测试4
- [root@web1 ~]# vim /usr/local/tomcat/conf/server.xml
- ...
- <Host name="www.b.com" appBase="web_b>
/ test" docBase="/abc" /> #path后面添加内容可以匹配用户访问路径,当用户访问www.b.com:8080/test/时,看到的是/abc的内容,如果访问www.b.com:8080就看到web_b/ROOT的内容- 重启tomcat
- [root@proxy tomcat]# curl www.b.com:8080/test/
- /abc/index.html
- [root@proxy tomcat]# curl www.b.com:8080
- web_b/ROOT/index.html
5)测试5
- [root@web1 ~]# vim /usr/local/tomcat/conf/server.xml
- ...
- <Host name="www.b.com" appBase="web_b">
- <Context path="/test" docBase="abc" /> #将/abc改成abc当用户访问www.b.com:8080/test/时,可以看到web_b/abc里的内容当用户访问www.b.com:8080时就看到web_b/ROOT的内容
- 重启tomcat
- [root@proxy tomcat]# curl www.b.com:8080/test/
- web_b/abc/index.html
- [root@proxy tomcat]# curl www.b.com:8080
- web_b/ROOT/index.html
Tomcat 工作原理

1)创建加密用的私钥和证书文件
- [root@web1 ~]# keytool -genkeypair -alias tomcat -keyalg RSA -keystore /usr/local/tomcat/keystore #提示输入密码为:123456
- #-genkeypair 生成密钥对
- #-alias tomcat 密钥别名
- #-keyalg RSA 定义密钥算法为RSA算法
- #-keystore 定义密钥文件存储在:/usr/local/tomcat/keystore
2)再次修改server.xml配置文件,创建支持加密连接的Connector
- [root@web1 ~]# vim /usr/local/tomcat/conf/server.xml
- ...
- <Connector port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol"
- maxThreads="150" SSLEnabled="true" scheme="https" secure="true"
- clientAuth="false" sslProtocol="TLS"
- keystoreFile="/usr/local/tomcat/keystore" keystorePass="123456"/>
- ...
- #备注,默认这段Connector被注释掉了,打开注释,添加密钥信息即可
3)重启Tomcat服务器
- [root@web1 ~]# /usr/local/tomcat/bin/shutdown.sh
- [root@web1 ~]# /usr/local/tomcat/bin/startup.sh
4)客户端设置host文件,并浏览测试页面进行测试(proxy可以充当客户端角色)
- [root@proxy ~]# vim /etc/hosts
- … …
- 192.168.99.100 www.a.com www.b.com
分别访问测试
https://www.a.com:8443/
https://www.b.com:8443/
1)为www.b.com虚拟主机开启日志
- [root@web1 ~]# vim /usr/local/tomcat/conf/server.xml
- .. ..
- <Host name="www.b.com" appBase="web_b" >
- ...
- #从默认localhost虚拟主机中把Valve这段复制过来,适当修改下即可
- <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
- prefix="www-b-com" suffix=".log"
- pattern="%h %l %u %t "%r" %s %b" />
- </Host>
2)重启Tomcat服务器
- [root@web1 ~]# /usr/local/tomcat/bin/shutdown.sh
- [root@web1 ~]# /usr/local/tomcat/bin/startup.sh
3)查看服务器日志文件
[root@web1 ~]# ls /usr/local/tomcat/logs/
Maven是一个软件项目管理工具,可以基于项目对象模型(POM),管理项目的构建、报告和文档。

POM (project Object Model) 项目对象模型,它是一个XML文件,包含了Maven创建项目的基本信息、构建过程项目依赖等
程序员编写项目时,需要使用各种依赖程序,之后还需要打包、测试之后才能发布到生产环境,这复杂的过程利用Maven可以极大的提高开发效率
可以配合Maven来提高开发效率的还有工具SpringBoot
可以创建独立应用,简化Maven配置

通过安装配置Maven,实现如下目标:
通过tar包安装Maven
将三个文件传入虚拟机root的家目录,原地释放
1)释放tar包,并拷贝到指定目录
- [root@web1 ~]# tar -xf apache-maven-3.6.3-bin.tar.gz
- [root@web1 ~]# mv apache-maven-3.6.3 /usr/local/maven
2)安装java依赖包
- [root@web1 ~]# yum -y install java-1.8.0-openjdk
- [root@web1 ~]# yum -y install java-devel
3)修改镜像地址,在第158行下添加
- [root@web1 ~]# vim /usr/local/maven/conf/settings.xml
- <mirror>
- <id>nexus-aliyun</id>
- <mirrorOf>*</mirrorOf>
- <name>Nexus aliyun</name>
- <url>http://maven.aliyun.com/nexus/content/groups/public</url>
- </mirror>
1)配置数据库
- [root@web1 ~]# yum install -y mariadb-server
- [root@web1 ~]# systemctl start mariadb
- [root@web1 ~]# cd CMS/
- [root@web1 CMS]# cp src/main/resources/shishuocms.properties . #拷贝网站数据库配置文件到当前目录,该文件定义了数据的用户名和密码等信息
- [root@web1 CMS]# mysql -uroot < sql/install.sql #导入网站相关数据库文件
- Enter password: 直接回车
- [root@web1 CMS]# mysqladmin password #修改数据库密码
- New password: #接下来输入12345678
- Confirm new password: #在输入一次12345678
如果数据库密码输入错误
mysqladmin password -uroot -p #改密码,先输入旧密码,然后输入两次新密码
如果数据库密码忘记
- systemctl stop mariadb #停服务
- yum -y remove mariadb-server #删除
- rm -rf /var/lib/mysql/ #删除数据库文件,这样密码就没了
- yum -y install mariadb-server #重装
- systemctl start mariadb #启动数据库
2)打包项目
- [root@web1 CMS]# /usr/local/maven/bin/mvn clean package #按照之前定义的
- 公网服务器地址、数据库配置等内容打包项目,注意该命令要在CMS目录进行
- cp ~/lnmp_soft/apache-tomcat-8.0.30/conf/server.xml /usr/local/tomcat/conf/
- cp: 是否覆盖 "/usr/local/tomcat/conf/server.xml"? y #把tomcat的配置文件恢复默认
-
- 重启tomcat
- rm -rf /usr/local/tomcat/webapps/ROOT #删除原有默认页面目录
-
- #将新项目移动到tomcat中,然后会自动解包,然后真机打开浏览器访问192.168.99.100:8080看到“师说”页面则成功
- cp target/shishuocms-2.0.1.war /usr/local/tomcat/webapps/ROOT.war