开发者社区> 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

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

相关文章
全方位解读服务网格(Service Mesh)的背景和概念
为了解决微服务框架的侵入性问题,我们引入服务网格。
1225 0
PolarDB 并行查询的前世今生
本文会深入介绍PolarDB MySQL在并行查询这一企业级查询加速特性上做的技术探索、形态演进和相关组件的实现原理,所涉及功能随PolarDB MySQL 8.0.2版本上线。
492 0
企业内部应用接入钉钉获取部门及人员信息
企业内部应用接入钉钉,同时通过API获取当前企业下部门及人员信息
1177 0
MySQL模糊查询再也用不着 like+% 了!
我们都知道 InnoDB 在模糊查询数据时使用 "%xx" 会导致索引失效,但有时需求就是如此,类似这样的需求还有很多,例如,搜索引擎需要根基用户数据的关键字进行全文查找,电子商务网站需要根据用户的查询条件,在可能需要在商品的详细介绍中进行查找,这些都不是B+树索引能很好完成的工作。 通过数值比较,范围过滤等就可以完成绝大多数我们需要的查询了。但是,如果希望通过关键字的匹配来进行查询过滤,那么就需要基于相似度的查询,而不是原来的精确数值比较,全文索引就是为这种场景设计的。
25667 0
阿里云云原生一体化数仓正式发布  助力企业数据驱动业务创新
云原生一体化数仓是集阿里云大数据产品MaxCompute、DataWorks、Hologres三种产品能力于一体的一站式大数据处理平台。核心是3个一体化和全链路数据治理能力,包括离线实时一体、湖仓一体、分析服务一体、全链路数据治理。
1599 0
全面公测|Grafana服务:一张图表胜过千行指标&日志
Grafana 帮助运维人员轻松处理各类运维过程中遇到的各类数据可视化与分析难题。目前阿里云 Grafana 服务全面免费公测,帮助企业轻松构建运维数据可视化平台,轻松实现数据驱动运维!
1142 0
一起学Golang系列(五)初次接触Go语言可能遇到的各种坑!
前面介绍了Go语言的基础语法,所谓磨刀不误砍柴工,希望大家还是能熟悉掌握这些基础知识,这样后面真正学起Go来才会得心应手。 作为初学者。Go语言的语法有些和java类似,但也有很多不一样的地方。刚开始都会遇到各种各样的坑。下面就来总结下学习go语言的过程中,遇到的各种坑。
1009 0
设备接入--海康摄像头SDK
springboot-对接海康摄像头,兼容window和Linux环境
1327 0
Flink SQL 在快手的扩展和实践
快手实时计算团队技术专家张静、张芒在 FFA 2021 的分享
1135 0
无影云桌面,企业与个人的应用神器
阿里云无影云桌面( Elastic Desktop Service)的原产品名为弹性云桌面,融合了无影产品技术后更名升级。它可以为您提供易用、安全、高效的云上桌面服务,帮助您快速构建、高效管理桌面办公环境,提供安全、灵活的办公体系。
276282 0
+关注
2
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载