R Shiny网页在服务器的部署


前言

以此文章记录我花了一整天的R Shiny部署过程。也为大家在未来的学习和部署提供参考。
我的服务器环境:阿里云CentOS 7.9


一、新建用户

shiny-server默认是以shiny用户来运行shiny应用的。在安装shiny-server的过程中,通常会创建一个名为shiny的用户。这是因为shiny-server的默认配置文件中,运行用户被设置为shiny,如果你在安装shiny-server时没有创建shiny用户,而是使用了其他的用户,那么你需要修改shiny-server的配置文件,将运行用户改为你创建的用户。否则,shiny-server可能无法正常运行。

1、在root账号下注册新账号,账号名为shiny。

useradd shiny

为账号设置密码

passwd shiny

在这里插入图片描述
2、接下来给用户添加root权限,这样就可以在用户账号下使用sudo命令了。通过修改sudoers文件来赋予新用户root权限。首先,查找sudoers文件的位置:

whereis sudoers

为其赋予写权限:

chmod -v u+w /etc/sudoers

在这里插入图片描述
使用vim打开并修改sudoers文件。

sudo vim /etc/sudoers

在文件中添加新用户信息,找到 root ALL=(ALL) ALL 该行,在下面添加 shiny ALL=(ALL) ALL,如果不想每次sudo都要输入密码,可以写这个 shiny ALL=(ALL) NOPASSWD: ALL,然后:wq保存并退出。

在这里插入图片描述
3、收回sudoers文件的写权限,防止他人篡改:

chmod -v u-w /etc/sudoers

在这里插入图片描述

二、安装R环境

1.安装R

首先进入用户账号

su - shiny

在这里插入图片描述
然后可以跟随官网步骤:https://posit.co/download/shiny-server/
Step1 - Select your server version :我的是CentOS 7+
Step 2 - Install EPEL :

sudo yum install epel-release -y

在这里插入图片描述
Step 3 - Install R and the Shiny R package : 如果用官网的代码

sudo yum install R

安装的不是最新版,我这里默认从EPEL安装的是R 3.6.0版本

在这里插入图片描述
如果满足不了项目需求,可以手动安装最新版。

2.如何安装最新版R

首先,需要安装一些必要的依赖项。可以使用以下命令安装它们:

sudo yum install -y gcc gcc-c++ gcc-gfortran readline-devel cairo-devel libpng-devel libjpeg-turbo-devel libtiff-devel pango-devel libicu-devel libxml2-devel libcurl-devel openssl-devel libXt-devel

在这里插入图片描述

接下来,需要下载R语言4.3.2包。可以使用以下命令从官方网站下载它:

wget https://cran.rstudio.com/src/base/R-4/R-4.3.2.tar.gz

在这里插入图片描述

下载完成后,需要解压缩该文件并进入解压缩后的目录:

tar -xzf R-4.3.2.tar.gz
cd R-4.3.2

在这里插入图片描述
现在,可以运行以下命令来配置和编译R语言:

./configure --prefix=/usr/local --enable-R-shlib
make
sudo make install

首先执行第一句:
在这里插入图片描述
报了个错,还需要安装bzip2,运行如下代码:

sudo yum install bzip2-devel

在这里插入图片描述

再次运行以下命令:

./configure --prefix=/usr/local --enable-R-shlib

在这里插入图片描述
又报错了,这里我们遵照提示,不用PCRE2了,改用PCRE1,运行:

./configure --prefix=/usr/local --enable-R-shlib --with-pcre1

在这里插入图片描述
这下第一句执行成功了,再执行第二句:

make

在这里插入图片描述
成功!再执行第三句:

sudo make install

在这里插入图片描述
编译完成后,可以使用以下命令启动R语言检查是否已安装最新版:

R

在这里插入图片描述

3.安装shiny包

继续遵照官网剩下的Step2安装shiny包:

sudo R -e "install.packages('shiny', repos = 'https://mirror.tuna.tsinghua.edu.cn/CRAN/')" #主动添加源,修改默认国外源

tips:如果sudo R报找不到命令的错误,可以手动输入R进入R语言,然后用install.packages(‘shiny’, repos = ‘https://mirror.tuna.tsinghua.edu.cn/CRAN/’)安装,我就是这样,如下图:

在这里插入图片描述
两次都是yes,因为运行不了sudo R所以权限不够,只能将包安装在用户目录下。

四、安装Shiny Server

遵照官网Step4 - Install Shiny Server :
首先进入/srv文件夹,一会把shiny-server-1.5.21.1012-x86_64.rpm文件下载到这,下载到其他地方也行。

cd /srv

运行:

sudo wget https://download3.rstudio.org/centos7/x86_64/shiny-server-1.5.21.1012-x86_64.rpm

在这里插入图片描述
安装server:

sudo yum install --nogpgcheck shiny-server-1.5.21.1012-x86_64.rpm

安装完成后可以执行以下代码查看server运行的状态:

sudo systemctl status shiny-server

在这里插入图片描述
绿色显示正在运行。在此也给出其他关于Shiny Server的指令:

##重启
sudo systemctl restart shiny-server
##查看状态 
sudo systemctl status shiny-server 
##开启 
sudo systemctl start shiny-server 
##停止 
sudo systemctl stop shiny-server

此时,在浏览器输入 <服务器ip>:3838 就可以访问shiny-server的默认主页(3838是shiny-server的默认端口号),比如我的服务器ip是112.124.7.213,那就输入112.124.7.213:3838。
在这里插入图片描述
注意公网ip需要开放服务器端口3838,即可正常访问,我用的是阿里云服务器,在服务器控制台 - 网络与安全 - 安全组
在这里插入图片描述
选择“操作栏”的“管理规则”,手动添加一栏
在这里插入图片描述

五、展示自己的网页

将自己的Rshiny项目复制进 /srv/shiny-server
在这里插入图片描述
图中shiny-app是我自己的项目,其余两个是官方示例。
我的shiny_app文件夹内容如下:
在这里插入图片描述
此时,通过 <服务器ip>:3838/<文件夹名> 即可访问,比如对于我就是112.124.7.213:3838/shiny_app


总结

还有不足理解不深的地方,请大家多指教。

03-28
### MCP API 的文档与使用教程 MCP 是一种用于增强大型语言模型 (LLM) 功能的技术框架,它通过提示(Prompts)、资源(Resources)以及工具(Tools)这三种核心原语来扩展 LLM 能力[^2]。Apifox 平台也认识到 MCP 技术在 API 开发领域的重要作用,并将其应用于实际场景中[^1]。 为了实现将 `/Users/syw/project/wechatAr` 文件夹下的所有文件上传至远程服务器 `47.93.xx.xx` 用户名 `root` 下的 `/opt/ll` 目录的操作,可以基于 MCP 工具功能构建一个自定义的服务逻辑。以下是具体实现方法: #### 实现方案 利用 SCP 命令完成文件传输任务,并结合 MCP 的 Tool 功能封装此操作以便于后续调用。当关键词为“上传微信目录”时,触发该工具执行相应动作。 ```python import subprocess def upload_wechat_directory(): source_dir = "/Users/syw/project/wechatAr/*" target_server = "root@47.93.xx.xx:/opt/ll/" try: result = subprocess.run(["scp", "-r", source_dir, target_server], check=True) return {"status": "success", "message": f"All files from {source_dir} have been uploaded to {target_server}"} except Exception as e: return {"status": "error", "message": str(e)} # 将上述函数注册为 MCP 中的一个 tool tools = { "upload_wechat_directory_tool": upload_wechat_directory, } # 定义 prompt 和 resource 配置部分省略... ``` 以上代码片段展示了如何创建一个名为 `upload_wechat_directory_tool` 的工具并将其集成到 MCP 系统里去[^3]。每当接收到匹配条件的消息比如含有特定关键字的时候就会激活对应的行为即启动SCP进程从而达成目标需求。 #### 进一步学习资料推荐 对于希望深入研究或者实践更多关于 MCP 应用案例的人士来说,《MCP 教程进阶篇》提供了丰富的实例分析和技术细节值得参考阅读;另外《MCP 极简入门:超快速上手运行简单的 MCP 服务和 MCP 客户端》同样是非常好的起点材料之一可以帮助初学者迅速掌握基础概念及其运作机制。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值