开发者社区> Aczy156> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

阿里云 Centos7 部署Java web [jar/war/nginx+域名服务]

简介: (一)第一部分:最基本的jar包运行(无需配置tomcat) [http://60.205.183.114:8081/] 1、配置阿里云(Esc学生服务器、镜像Centos7.7),并远程连接进入终端。
+关注继续查看

(一)第一部分:最基本的jar包运行(无需配置tomcat)

[http://60.205.183.114:8081/]

a)安装jdk。
b)寻找jdk路径配置环境变量。
c)简单的Java hello world测试确保安装成功。

a)安装mysql、mariadb server。
b)systemctl 开启服务。
c) 打开端口。(阿里云要在控制台打开,参考https://yq.aliyun.com/articles/701181)
d) 更改mysql 的root密码,对应于项目配置文件中的密码。

a)传输spring maven 的快照版本用于测试。
b)传输数据库sql文件。

  • 5、导入数据库

a)创建sql文件对应的数据库。
b)利用文件重定向运行sql文件。
c)检查数据库是否导入成功

  • 6、运行jar文件,控制台获取公网IP,本机输入IP:8081测试。
  • 7、设置后台运行(已设置:http://60.205.183.114:8081/)

a)contrl+c中止。
b)然后通过nohup 和 & 来后台运行。
c)ps通过pid来停止后台运行进程。

运行结果
整体过程:

[root@iZ2ze4r3b4xcztbcsey08cZ ~]# history
    1   MAKRER=SHOW_LOCALE;printf $MAKRER""; locale; MAKRER=SHOW_LOCALE;printf $MAKRER"";
    2  yum install -y mysql
    3  yum install -y mariadb-server mariadb
    4  systemctl start mariadb
    5  systemctl enable mariadb
    6  yum install -y mysql-devel
    7  firewall-cmd --zone=public --add-port=3306/tcp --permanent
    8   CHECK_TYPE=SHELL; echo "INFO=${CHECK_TYPE} PID=$$ PPID=$PPID TTY=$(tty) SHELL=$0 HOME=$HOME PWD=$PWD| CHECK_SHELL_END"
    9  ls
   10  ifconfig
   11  ls
   12  yum list
   13  java -version
   14  ls
   15  yum search java-1.8
   16  yum -y install java-1.8.0-openjdk-devel.x86_64
   17  java -version
   18  cd /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.252.b09-2.el7_8.x86_64/
   19  pwd
   20  vim /etc/profile
   21  . /etc/profile
   22  vim Demo.java
   23  javac  Demo.java
   24  java Demo
   25  su
   26   MAKRER=SHOW_LOCALE;printf $MAKRER""; locale; MAKRER=SHOW_LOCALE;printf $MAKRER"";
   27   CHECK_TYPE=SHELL; echo "INFO=${CHECK_TYPE} PID=$$ PPID=$PPID TTY=$(tty) SHELL=$0 HOME=$HOME PWD=$PWD| CHECK_SHELL_END"
   28  mysql -u root
   29  ls
   30  pwd
   31  ifconfig
   32  ls
   33  mysql
   34  mysql -u root jpetstore < jpetstore.sql
   35  mariadb
   36  mysql
   37  java -jar mypetstore-0.0.3-SNAPSHOT.jar
   38  nohup java -jar mypetstore-0.0.3-SNAPSHOT.jar &
   39  ps
   40  history
[root@iZ2ze4r3b4xcztbcsey08cZ ~]# 

控制台开端口

利用scp传文件
image

运行mysql 文件

[root@iZ2ze4r3b4xcztbcsey08cZ ~]# mysql
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 3
Server version: 5.5.65-MariaDB MariaDB Server

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> create database jpetstore;
Query OK, 1 row affected (0.00 sec)

MariaDB [(none)]> quit
Bye
[root@iZ2ze4r3b4xcztbcsey08cZ ~]# mysql -u root jpetstore < jpetstore.sql 
[root@iZ2ze4r3b4xcztbcsey08cZ ~]# mariadb
-bash: mariadb: command not found
[root@iZ2ze4r3b4xcztbcsey08cZ ~]# mysql
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 5
Server version: 5.5.65-MariaDB MariaDB Server

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| jpetstore          |
| mysql              |
| performance_schema |
| test               |
+--------------------+
5 rows in set (0.00 sec)

MariaDB [(none)]> use jpetstore;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
MariaDB [jpetstore]> show tables;
+---------------------+
| Tables_in_jpetstore |
+---------------------+
| account             |
| addlog              |
| bannerdata          |
| browselog           |
| cart                |
| cartitem            |
| category            |
| inventory           |
| item                |
| lineitem            |
| orders              |
| orderstatus         |
| product             |
| profile             |
| sequence            |
| signon              |
| supplier            |
+---------------------+
17 rows in set (0.00 sec)

访问http://60.205.183.114:8081/

image

(二)第二部分:利用Tomcat容器对war包进行处理(需要Tomcat)

[http://60.205.183.114:8080/myJPetStore_war/index.jsp]

a)本地下载tomcat,然后利用scp文件传输
b)设置访问权限
c)设置服务配置
d)输入IP:8080测试是否已经开启服务

  • 2、数据库/端口配置

a)数据库root 密码 和服务器对应
b)端口配置,在上面已经开启了8080端口

  • 3、利用scp传输war包,放到webapp里边(直接会解析出文件)
  • 4、重启tomcat服务

a)bin下的shutdown.sh
b)bin下的startup.sh

  • 5、本机测试访问

a)注意要添加访问的资源的路径/myJPetStore_war/index.jsp,然后tomcat容器会自动到webapp下去寻找
b) 已设置tomcat容器:http://60.205.183.114:8080/myJPetStore_war/index.jsp

运行结果
整体过程

   52  ls
   53  sudo mkdir /opt/tomcat
   54  sudo tar xvf apache-tomcat-8*tar.gz -C /opt/tomcat --strip-components=1
   55  cd /opt/tomcat
   56  sudo chgrp -R tomcat /opt/tomcat
   57  sudo chmod -R g+r conf
   58  sudo chmod g+x conf
   59  sudo chown -R tomcat webapps/ work/ temp/ logs/
   60  sudo vi /etc/systemd/system/tomcat.service
   61  sudo systemctl daemon-reload
   62  sudo systemctl start tomcat
   63  sudo systemctl status tomcat
   64  sudo systemctl enable tomcat
   65  ls
   66  cd webapps/
   67  pwd
   68  ls
   69  sudo systemctl restart tomcat
   70  cd ../bin/
   71  ls
   72  sh shutdown.sh 
   73  sh startup.sh 
   74  history
[root@iZ2ze4r3b4xcztbcsey08cZ bin]# 

利用systemctl查看tomcat的状态
image

验证是否开启tomcat服务
image

将war包直接传入webapp中
image

然后webapp会自动解析war包(即myJPetStore_war)

[root@iZ2ze4r3b4xcztbcsey08cZ webapps]# pwd
/opt/tomcat/webapps
[root@iZ2ze4r3b4xcztbcsey08cZ webapps]# ls
docs  examples  host-manager  manager  myJPetStore_war  myJPetStore_war.war  ROOT

访问http://60.205.183.114:8080/myJPetStore_war/index.jsp

image

(三)第三部分:指定域名进行访问

[http://crf.codes/]

  • 1、配置virmach vps,达到可以通过IP进行访问

a)过程同第一步,最后设置为后台运行。
b) 已配置:http://198.12.120.212:8081/

a)Web server 设定域名
b)Location 配置index界面
c)开放Linux系统防火墙
d)访问crf.code http://crf.codes/

运行结果
域名提供商(name)配置dns

image

验证dns是否配置成功
ping crf.codes,可以看到
image

修改nginx配置文件

server {
    listen       80;
    server_name   crf.codes;

    #charset koi8-r;
    access_log  /var/log/nginx/host.access.log  main;

    location / {
        # root   /usr/share/nginx/html;
        index  index.html index.htm;
        proxy_pass http://127.0.0.1:8081/;
        # proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #    deny  all;
    #}
}

访问crf.codes

image

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
java实现MsOffice文档向pdf转化之OpenOffice软件
本篇文档实现功能,将word和excel,ppt文档的文件转化成pdf格式的文档 第一步:下载第三方软件OpenOffice软件(不同的操作系统下载不同的版本)    下载地址:http://www.
931 0
采用linux下java http实现下载功能
[root@luozhonghua javacode]# vi getHttpResource.java [root@luozhonghua javacode]# cat getHttpResource.java /**   http获取文件   luozhonghua */ import java.io.*; import java.net.*; public class
1829 0
java实现MsOffice文档向pdf文档转化
本篇文档实现功能,将word和ppt文档的文件转化成pdf格式的文档 应用到jacob   第一步:下载压缩包 (1)jacob官网下载jacob压缩包 (2)网址:http://sourceforge.
1010 0
java编程排序之内置引用类型的排序规则实现,和自定义规则实现+冒泡排序运用
第一种排序:【冒泡排序】基本数据类型的排序。 【1】最简易的冒泡排序。效率低。因为比较的次数和趟数最多。 1 /** 2 * 最原始的冒泡排序。 3 * 效率低。
1650 0
java中Comparable实现对象的比较
/* class A implements Comaprable{ } 那么 A x = new A(); 类关系图 Object o = A; Object Compa...
641 0
java简单的实现搜索框的下拉显示相关搜索功能
最近做了一个简单的搜索框下面下拉显示相关搜索的功能,有点模仿百度的下拉展示相关搜索   先上个展示图 : 点击进入演示地址,大家可以输入长点的搜索,点击搜索,再输入之前搜索词的前面部分,看是否能展示出来   搜索框相关搜索的展示很简单,就是根据你的搜索词,去数据库中匹配,是否有类似的搜索词存...
1537 0
+关注
文章
问答
文章排行榜
最热
最新
相关电子书
更多
阿里特邀专家徐雷Java Spring Boot开发实战系列课程(第18讲):制作Java Docker镜像与推送到DockerHub和阿里云Docker仓库
立即下载
从Web到Cloud App——YunOS Web App 开发经验分享
立即下载
《Nginx 代理系统常用手册》
立即下载