前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >如何在Ubuntu 14.04上部署Clojure Web应用程序

如何在Ubuntu 14.04上部署Clojure Web应用程序

原创
作者头像
风研雨墨
修改2018-09-26 09:49:56
1.4K0
修改2018-09-26 09:49:56
举报

介绍

人们对函数式编程的兴趣不断增加,更具体地说,是在Clojure中对Web进行编程。许多关于如何构建基本应用程序的教程经常忽略部署细节。本文将向您展示如何将Clojure Web应用程序部署到Ubuntu 14.04 CVM。

具体来说,我们将创建一个示例Clojure应用程序并将其打包以供制作使用,并使用Supervisor在服务器上设置Clojure应用程序环境以运行应用程序和Nginx向其提供请求。

准备

在开始本教程之前,您需要准备以下内容:

第一步 - 创建和打包示例Clojure应用程序

第一步是使用git抓取示例Clojure项目进行部署。

首先,更新软件包并在服务器上安装git

代码语言:javascript
复制
sudo apt-get update
sudo apt-get install git

接下来,克隆示例项目存储库。

代码语言:javascript
复制
git clone https://github.com/do-community/do-clojure-web.git

此存储库是遵循Clojure Basic Web Development教程的最终结果。如果您愿意,可以自己学习该教程,而不是克隆此存储库。

Clojure利用JVM来运行其代码,因此您需要编译项目来运行它。Leiningen是Clojure应用程序的依赖管理和构建自动化工具,可以轻松实现。有两个步骤可以让Leiningen成立。

首先,安装Java。

代码语言:javascript
复制
sudo apt-get install openjdk-7-jre-headless

接下来下载Leiningen安装脚本。Leiningen有一个Ubuntu软件包,但它已经过时了。

代码语言:javascript
复制
sudo curl https://raw.githubusercontent.com/technomancy/leiningen/stable/bin/lein -o /usr/local/bin/lein

设置权限,以便任何用户都可以使用Leiningen提供的lein实用程序。

代码语言:javascript
复制
sudo chmod a+x /usr/local/bin/lein

现在您可以编译您的项目以在服务器上运行lein

代码语言:javascript
复制
cd ~/do-clojure-web
lein uberjar

第二步 - 设置Clojure应用程序环境

我们需要三个主要部分才能使此应用程序正常工作:Java,Supervisor和Nginx。我们刚刚安装了Java,接下来,我们将安装Supervisor和Nginx。

代码语言:javascript
复制
sudo apt-get install nginx supervisor

您还需要一个地方来保存您的Clojure Web应用程序及其日志文件。接下来创建该目录结构。

代码语言:javascript
复制
sudo mkdir -p /var/www/do-clojure-web/app/db /var/www/logs

现在,您可以将Clojure应用程序文件和数据库文件移动到您创建的目录中。

代码语言:javascript
复制
sudo cp ~/do-clojure-web/target/do-clojure-web-0.1.0-standalone.jar /var/www/do-clojure-web/app/
sudo cp ~/do-clojure-web/db/do-clojure-web.h2.db /var/www/do-clojure-web/app/db/

应用程序将作为系统上的用户www-data运行,以便它可以写入我们的内置数据库。将应用程序路径的所有者设置为www-data

代码语言:javascript
复制
sudo chown -R www-data /var/www/do-clojure-web/

切换到Clojure应用程序目录。

代码语言:javascript
复制
cd /var/www/do-clojure-web/app/

在生产环境中,应用程序的版本号将随每次更新而更改。您不希望每次都发生更新系统配置。要防止这种情况,请为当前运行的应用程序版本创建符号链接。您将在接下来的步骤中引用符号链接。

代码语言:javascript
复制
sudo ln -s do-clojure-web-0.1.0-standalone.jar do-clojure-web.jar

该应用程序当前配置为只能通过localhost访问,但您仍然可以确保它启动时没有错误。在继续之前这样做。

代码语言:javascript
复制
sudo java -jar do-clojure-web.jar

如果一切正常,你应该得到类似这样的输出:

代码语言:javascript
复制
. . .
2015-06-12 04:30:17.882:INFO:oejs.Server:jetty-7.x.y-SNAPSHOT
2015-06-12 04:30:17.995:INFO:oejs.AbstractConnector:Started SelectChannelConnector@127.0.0.1:5000

按下组合键CTRL+C,立即停止应用程序。

第三步 - 配置Supervisor以运行Clojure应用程序

这有几个选项作为服务来管理应用程序。你在这里使用的选项叫做Supervisor ; 它比简单的脚本更容易管理,更通用。但是,对于真正需要扩展的服务,请查看有关运行Clojure应用程序的uWSGI文档

创建和编辑/etc/supervisor/conf.d/do-clojure-web.conf文件。

代码语言:javascript
复制
sudo nano /etc/supervisor/conf.d/do-clojure-web.conf

将此配置添加到文件并保存。

代码语言:javascript
复制
[program:do-clojure-web]
command=/usr/bin/java -jar do-clojure-web.jar
directory=/var/www/do-clojure-web/app
user=www-data
autostart=true
autorestart=true
startretries=3
redirect_stderr=true
stdout_logfile=/var/www/logs/do-clojure-web.app.log

这种配置非常简单。Supervisor守护程序(服务)将从/var/www/do-clojure-web/app目录中运行我们的应用程序。如果/var/www/logs/do-clojure-web.app.log崩溃,它还将确保登录并尝试重新启动应用程序。

第四步 - 将Nginx配置为代理服务器

因为Clojure Web应用程序只接受来自端口5000上localhost的连接,所以我们需要在其前面放置一个像Nginx这样的Web服务器来提供外部访问。在扩展应用程序时,这对于提供静态资产也非常方便。

编辑/etc/nginx/sites-available/default文件。

代码语言:javascript
复制
sudo nano /etc/nginx/sites-available/default

将一下注释的代码块部分添加到文件中。这定义了我们的后端,以便在下一个配置部分中参考。

代码语言:javascript
复制
. . .
# Please see /usr/share/doc/nginx-doc/examples/ for more detailed examples.
##
upstream http_backend { //添加到文件中
    server 127.0.0.1:5000;
    keepalive 32;
}
server {
    listen 80 default_server;
. . .

现在找到以location /开头的块。通过在每行的开头添加一个#来注释掉其中的所有行。

代码语言:javascript
复制
. . .
        # Make site accessible from http://localhost/
        server_name localhost;
​
​
        # location / {
                # First attempt to serve request as file, then
                # as directory, then fall back to displaying a 404.
                # try_files $uri $uri/ =404;
                # Uncomment to enable naxsi on this location
                # include /etc/nginx/naxsi.rules
        # }
​
        # Only for nginx-naxsi used with nginx-naxsi-ui : process denied requests
. . .

然后,在下面添加以下部分,它将告诉Nginx像端口80上的普通Web服务器一样监听并将您的请求代理到Clojure应用程序。

代码语言:javascript
复制
. . .
​
        # Only for nginx-naxsi used with nginx-naxsi-ui : process denied requests
​
    location / {
        proxy_pass http://http_backend;
​
        proxy_http_version 1.1;
        proxy_set_header Connection "";
​
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
​
        access_log /var/www/logs/do-clojure-web.access.log;
        error_log /var/www/logs/do-clojure-web.error.log;
    }
​
        #location /RequestDenied {
        #       proxy_pass http://127.0.0.1:8080;    
        #}

第五步 - 启动服务和测试访问

现在是时候开始所有的工作,并确保一切正常。继续并启动Supervisor守护程序,以便您的Clojure应用程序启动。

代码语言:javascript
复制
sudo service supervisor start 

等待大约30秒才能启动,然后启动Nginx Web服务器前端代理。

代码语言:javascript
复制
sudo service nginx start

在您的浏览器访问 http://your_server_ip。您应该看到示例Clojure应用程序站点加载。

如果您只是获取默认的Nginx页面,请尝试用 sudo service supervisor restart重启Supervisor,等待30秒,然后用sudo service nginx restart重新启动Nginx 。

加载网站后,单击屏幕顶部的“ 添加位置”链接,尝试添加一些数字坐标以确保数据库访问权限正确。例如,您可以为x值添加1,为y值添加2 。这会带你到一个页面说:

代码语言:javascript
复制
Added [1, 2] (id: 1) to the db. See for yourself.

如果单击屏幕顶部的“ 查看所有位置”链接,您应该会看到包含新条目的表格。

结论

您刚刚使用Leiningen,Supervisor和Nginx部署了Clojure应用程序!有关部署甚至最简单的网站和应用程序的主题还有很多东西需要学习。下一步是部署自定义应用程序,但不是本教程中使用的示例应用程序。

想要了解更多关于Linux开源信息教程,请前往腾讯云+社区学习更多知识。

参考文献:《How To Deploy a Clojure Web Application on Ubuntu 14.04》

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 介绍
  • 准备
  • 第一步 - 创建和打包示例Clojure应用程序
  • 第二步 - 设置Clojure应用程序环境
  • 第三步 - 配置Supervisor以运行Clojure应用程序
  • 第四步 - 将Nginx配置为代理服务器
  • 第五步 - 启动服务和测试访问
  • 结论
相关产品与服务
云开发 CloudBase
云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档