R 使用自定义图像在OpenShift Online上运行闪亮的应用程序
我是OpenShift的新手,目前正在使用OpenShift online探索其功能。我创建了一个简单的R-Shining应用程序,并创建了以下Dockerfile以在OpenShift中构建自定义图像R 使用自定义图像在OpenShift Online上运行闪亮的应用程序,r,docker,shiny,openshift,openshift-online,R,Docker,Shiny,Openshift,Openshift Online,我是OpenShift的新手,目前正在使用OpenShift online探索其功能。我创建了一个简单的R-Shining应用程序,并创建了以下Dockerfile以在OpenShift中构建自定义图像 # Base image https://hub.docker.com/u/rocker/ FROM rocker/shiny:latest # expose port EXPOSE 3838 # system libraries of general use ## install debi
# Base image https://hub.docker.com/u/rocker/
FROM rocker/shiny:latest
# expose port
EXPOSE 3838
# system libraries of general use
## install debian packages
RUN apt-get update -qq && apt-get -y --no-install-recommends install \
libxml2-dev \
libcairo2-dev \
libsqlite3-dev \
libmariadbd-dev \
libpq-dev \
libssh2-1-dev \
unixodbc-dev \
libcurl4-openssl-dev \
libssl-dev
## update system libraries
RUN apt-get update && \
apt-get upgrade -y && \
apt-get clean
# copy necessary files
## app folder
RUN mkdir -p /srv/shiny-server/soker
COPY docker.Rproj /srv/shiny-server/soker
COPY server.R /srv/shiny-server/soker
COPY ui.R /srv/shiny-server/soker
COPY renv.lock /srv/shiny-server/soker
COPY server.R /srv/shiny-server/soker
COPY renv /srv/shiny-server/soker/renv
# install renv & restore packages
RUN Rscript -e 'install.packages("renv")'
RUN Rscript -e 'renv::consent(provided = TRUE)'
RUN Rscript -e 'renv::restore()'
RUN chown -R shiny /srv/shiny-server/
RUN chown -R shiny /var/lib/shiny-server/
# Run as a non-root user
USER 997
# run app on container start
CMD ["R", "-e", "shiny::runApp( '/srv/shiny-server/soker',host = '0.0.0.0', port = 3838)"]
此DockerFile位于源文件夹中,包含以下server.R和ui.R文件
服务器.R
server <- function(input, output) {
output$distPlot <- renderPlot({
x <- faithful$waiting
bins <- seq(min(x), max(x), length.out = input$bins + 1)
hist(x, breaks = bins, col = "#75AADB", border = "white",
xlab = "Waiting time to next eruption (in mins)",
main = "Histogram of waiting times")
})
}
我是不是遗漏了什么?如何将端口3838添加为容器的默认端口?我已经使用Docker在本地环境上运行了这个应用程序,我可以通过键入localhost:3838来访问这个闪亮的应用程序。为了让OpenShift识别一个暴露的端口,我相信您需要在Docker文件上的
标签中表达这一点
LABEL io.openshift.expose-services="8080:http"
来源:为了让OpenShift识别暴露的端口,我相信您需要在Dockerfile上的标签中表达这一点
LABEL io.openshift.expose-services="8080:http"
来源:Hi,我尝试添加标签,但仍然没有使用端口3838Ok,可能这更像是oc
版本问题。我刚刚用您在原始问题中提供的Dockerfile对其进行了测试,结果与预期一样:-containerPort:3838
。这是在oc版本
4.4.6中实现的。您使用的是什么版本?我正在OpenShift Online中运行此版本,版本为v3.11.154。您将此标记为已回答,它现在对您有效吗?是的。终于成功了,我想我上一次犯了个错误。谢谢您的回答。您好,我尝试添加标签,但仍然没有使用端口3838 OK,可能这更像是oc
版本问题。我刚刚用您在原始问题中提供的Dockerfile对其进行了测试,结果与预期一样:-containerPort:3838
。这是在oc版本
4.4.6中实现的。您使用的是什么版本?我正在OpenShift Online中运行此版本,版本为v3.11.154。您将此标记为已回答,它现在对您有效吗?是的。终于成功了,我想我上一次犯了个错误。谢谢你的回答。
"spec": {
"containers": [
{
"name": "newapp",
"image": "newapp:latest",
"ports": [
{
"containerPort": 8080,
"protocol": "TCP"
},
{
"containerPort": 8443,
"protocol": "TCP"
}
],
"resources": {}
}
]
}
}
},
LABEL io.openshift.expose-services="8080:http"