Linux相信对大多数程序员来讲都不陌生,毕竟在服务器端依然仍是霸主地位并且丝毫没有退居二线的意思,以致于如今几乎每个软件开发的相关人员都得或多或少的知道一些Linux的相关内容,本文将介绍如何在刚拿到一台云服务器(采用centos
)来进行运行环境的搭建,包括JDK
、Mysql
、Tomcat
以及nginx
。相信对于小白来讲颇有必要的,也是我我的的一个记录。php
该服务器的用途是用于部署JavaEE项目。 部署以后的效果图以下:
html
因为咱们以后须要部署的是JavaEE
项目,因此首先第一步就是安装JDK了。java
如今的服务器拿来以后通常都是默认给咱们安装一个openJDK
,首先咱们须要卸载掉。node
rpm -qa | grep java
命令查看系统中是否存在有Java。rpm -e --nodeps 相关应用名称
来进行卸载。(相关应用名称就是上一个命令中显示出来的名称复制到这里卸载便可)。ORACLE
所提供的JDK,传送门根据本身系统的状况下载对应版本便可。笔者使用的是jdk-8u101-linux-x64.rpm
版本。/usr/java
目录下便可,没有java
目录新建一个便可。rpm -ivh jdk-8u101-linux-x64.rpm
命令进行解压安装。安装完成以后使用vi /etc/profile
命令编辑profile
文件(注意该文件路径是指根目录下的etc文件夹不要找错了)。 在该文件中加入如下内容:mysql
export JAVA_HOME=/usr/java/jdk-8u101-linux-x64 export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar export PATH=$PATH:$JAVA_HOME/bin
保存以后运行source /etc/profile
使配置生效。linux
以后咱们使用在windows
平台也有的命令java -version
,若是输出如图: 表示安装成功。nginx
首先第一步仍是要卸载掉自带的mysql。 rpm -e --nodeps mysql
命令和以前同样只是把应用名称换成mysql了而已。git
yum
来安装mysql以后咱们采用yum
来安装mysql。这样的方式最简单便捷。 yum install -y mysql-server mysql mysql-deve
执行该命令直到出现Complete!
提示以后表示安装成功。 rpm -qi mysql-server
以后使用该命令能够查看咱们安装的mysql信息。程序员
使用service mysqld start
来启动mysql服务(第一次会输出不少信息),以后就不会了。 而后咱们可使用chkconfig mysqld on
命令将mysql设置为开机启动。 输入chkconfig --list | grep mysql
命令显示以下图: 表示设置成功。 使用
mysqladmin -u root password 'root'
为root
帐户设置密码。github
grant all privileges on *.* to 'root'@'%' identified by '123456' with grant option; # root是用户名,%表明任意主机,'123456'指定的登陆密码(这个和本地的root密码能够设置不一样的,互不影响) flush privileges; # 重载系统权限 exit;
使用mysql -u root -proot
来登陆mysql。若是出现如下界面表示设置成功。
Tomcat
也是咱们运行JavaEE
项目必备的一个中间件。
apache-tomcat-8.5.5.tar.gz
上传到/usr/local
目录中。tar -zxv -f apache-tomcat-8.5.5.tar.gz
,再使用mv apache-tomcat-8.5.5 tomcat
将解压的Tomcat移动到外层的Tomcat
目录中。/usr/local/tomcat/apache-tomcat-8.5.5/bin
目录使用./startup.bat
命令启动tomcat。8080
,linux防火墙默认是不能访问的,须要手动将其打开。使用vi + /etc/sysconfig/iptables
编辑iptables
(注意etc目录是根目录下的),加入如下代码:-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 8080 -j ACCEPT -A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT
这里咱们开放了8080和80端口,以后安装ngix就不用在开放了。
ps:这里用到了简单的vim命令。按
i
进入插入模式,输入上面两段代码。以后按esc
退出插入模式。再按:wq
保存关闭便可。 以后使用service iptables restart
命令重启防火墙便可。在浏览器输入服务器的ip+8080
若是出现Tomcat的欢迎页即代表Tomcat
安装成功。
最后是安装nginx
,这里咱们仍是使用最简单的yum
的方式来进行安装。
yum -y install pcre* yum -y install openssl* yum -y install gcc
cd /usr/local/ wget http://nginx.org/download/nginx-1.4.2.tar.gz tar -zxvf nginx-1.4.2.tar.gz cd nginx-1.4.2 ./configure --prefix=/usr/local/nginx --with-http_stub_status_module make make install
/usr/local/nginx/sbin/nginx
命令来启动nginx了。输入服务器的IP地址,若是出现nginx的欢迎界面表示安装成功了。这里我就简单贴如下个人配置,主要就是配置一个upstream,
以后在server
中引用配置的那个upstream
便可。
#user nobody; worker_processes 1; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid logs/nginx.pid; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; #log_format main '$remote_addr - $remote_user [$time_local] "$request" ' # '$status $body_bytes_sent "$http_referer" ' # '"$http_user_agent" "$http_x_forwarded_for"'; #access_log logs/access.log main; sendfile on; #tcp_nopush on; #keepalive_timeout 0; keepalive_timeout 65; #gzip on; upstream crossover_main { server 127.0.0.1:8080; } server { listen 80; server_name www.crossoverjie.top; #charset koi8-r; #access_log logs/host.access.log main; location / { proxy_pass http://crossover_main/examples/; proxy_set_header Host $http_host; proxy_set_header X-Forwarded-For $remote_addr; index index.jsp; } #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 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; #} } # another virtual host using mix of IP-, name-, and port-based configuration # #server { # listen 8000; # listen somename:8080; # server_name somename alias another.alias; # location / { # root html; # index index.html index.htm; # } #} # HTTPS server # #server { # listen 443; # server_name localhost; # ssl on; # ssl_certificate cert.pem; # ssl_certificate_key cert.key; # ssl_session_timeout 5m; # ssl_protocols SSLv2 SSLv3 TLSv1; # ssl_ciphers HIGH:!aNULL:!MD5; # ssl_prefer_server_ciphers on; # location / { # root html; # index index.html index.htm; # } #} }
以后咱们在地址栏输入服务器的IP地址(若是有域名解析了服务器的IP能够直接输入域名)就会进入咱们在upstream
中配置的地址加上在server
中的地址。根据我这里的配置最后解析地址就是http://127.0.0.1:8080/examples
应该是很好理解的。最终的结果是我在片头放的那张截图同样。
这是一个简单的基于centOS的运行环境配置,对于小白练手应该是够了,有不清楚和错误的地方欢迎指出反正我也不会回复。
我的博客地址:http://crossoverjie.top。
GitHub地址:https://github.com/crossoverJie。