- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将Keycloak设置为IdP(身份提供商)并将Nextcloud设置为服务。我想将Keycloak设置为呈现SSO(单点登录)页面。
我正在运行具有Intel兼容CPU的Linux服务器。什么是正确的配置?
Keycloak将以https://kc.domain.com的身份运行
Nextcloud将以https://nc.domain.com的身份运行
最佳答案
先决条件
要使用此答案,您需要将domain.com
替换为您拥有的实际域。另外,将email@domain.com
替换为您的工作电子邮件地址。
假设您已安装并正在运行docker和docker-compose。
使用Docker设置服务
除了keycloak和nextcloud之外,我还使用:
Nginx作为反向代理
letsencyrpt可以为子域生成SSL证书。
我正在使用docker和docker-compose设置所有必需的服务。 docker-compose.yml
的外观如下所示:
version: '2'
nginx-proxy:
image: jwilder/nginx-proxy
restart: unless-stopped
ports:
- "80:80"
- "443:443"
volumes:
- "/etc/nginx/vhost.d"
- "./proxy-default.conf:/etc/nginx/conf.d/my-proxy.default.conf:ro"
- "/usr/share/nginx/html"
- "/var/run/docker.sock:/tmp/docker.sock:ro"
- "./le-cert:/etc/nginx/certs:ro"
labels:
com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy: "true"
letsencrypt-nginx-proxy-companion:
image: jrcs/letsencrypt-nginx-proxy-companion
restart: unless-stopped
depends_on:
- nginx-proxy
container_name: le-proxy-companion
volumes:
- "/var/run/docker.sock:/var/run/docker.sock:ro"
- "./le-cert:/etc/nginx/certs:rw"
volumes_from:
- nginx-proxy
keycloak:
image: jboss/keycloak
links:
- keycloak-postgres:postgres
ports:
- 8080:8080
volumes:
- ./keycloak:/opt/jboss/keycloak
environment:
- KEYCLOAK_USER=admin
- KEYCLOAK_PASSWORD=admin
- "PROXY_ADDRESS_FORWARDING=true"
- VIRTUAL_PORT=8080
- VIRTUAL_HOST=kc.domain.com
- LETSENCRYPT_HOST=kc.domain.com
- LETSENCRYPT_EMAIL=email@domain.com
keycloak-postgres:
image: postgres
environment:
- POSTGRES_DB=keycloak
- POSTGRES_USER=keycloak
- POSTGRES_PASSWORD=keycloak
nextcloud:
image: hoellen/nextcloud
environment:
- UPLOAD_MAX_SIZE=10G
- APC_SHM_SIZE=128M
- OPCACHE_MEM_SIZE=128
- CRON_PERIOD=15m
- TZ=Europe/Berlin
- DOMAIN=nc.domain.com
- ADMIN_USER=admin
- ADMIN_PASSWORD=admin
- DB_TYPE=mysql
- DB_NAME=nextcloud
- DB_USER=nextcloud
- DB_PASSWORD=nextcloud
- DB_HOST=nc-db
volumes:
- ./nc/nc-data:/data
- ./nc/nc-config:/config
- ./nc/nc-apps:/apps2
- ./nc/nc-themes:/nextcloud/themes
environment:
- VIRTUAL_HOST=nc.domain.com
- LETSENCRYPT_HOST=nc.domain.com
- LETSENCRYPT_EMAIL=email@domain.com
nc-db:
image: mariadb
volumes:
- ./nc/nc-db:/var/lib/mysql
environment:
- MYSQL_ROOT_PASSWORD=nextcloud
- MYSQL_PASSWORD=nextcloud
- MYSQL_DATABASE=nextcloud
- MYSQL_USER=nextcloud
docker
中,在该文件夹中有一个项目特定的文件夹。在这里
keycloak
。使用以下方法创建它们:
mkdir -p ~/docker/keycloak
docker-compose.yml
-文件。通过以下方式启动服务:
cd ~/docker/keycloak
docker-compose up -d
docker-compose ps
docker-compose up -d
并再次检查。
docker-compose.yml
中的指定,用户名和密码为
admin
。
Add
。输入my-realm作为名称。单击
Save
。
Keys
-选项卡。查看
RSA
条目。我们将需要复制该行的证书。单击
Certificate
,然后将内容复制粘贴到文本编辑器中,以备后用。
openssl req -nodes -new -x509 -keyout private.key -out public.cert
private.key
和
public.cert
,稍后我们需要nextcloud服务。
docker-compose.yml
中的指定,用户名和密码为
admin
。
SSO & Saml Authenticate
。
+ Apps
符号。现在在左侧看到带有条目
Security
的菜单栏。点击它。现在,您将看到所有已实现安全性的应用。单击
Activate
应用程序下方的
SSO & SAML authentication
按钮。
Admin
。点击
SSO & SAML authentication
。
public.cert
的内容复制到“ X.509证书”字段中
private.key
的内容复制到“服务提供商的私钥”字段中。
Keys
的
my-realm
选项卡中的Keycloak复制证书。您将需要在密钥前面添加“ ----- BEGIN CERTIFICATE -----”,并在其末尾添加“ ----- END CERTIFICATE -----”。
Download metadata XML
并保存文件以进行下一步。
Metadata valid
-按钮旁边是否有
Download metadata XML
Download metadata XML
-按钮。这将生成并发送XML文件。保存。
Clients
,然后在右上角单击
Create
-按钮。
Select File
-按钮。选择您在Nextcloud的最后一步中创建的XML文件。
Save
。
Save
Matters
上:
Delete
上的
role list
-按钮
Create
Save
Create
Save
Create
Save
Users
Add users
Save
Credentials
上:
Reset Password
Change Password
Ctrl-Shift-N
,在Firefox中按
Ctrl-Shift-P
。保持另一个浏览器窗口打开nextcloud设置页面。否则,您可能会被锁定。
user
作为名称和密码。应该用nextcloud欢迎屏幕打招呼。
关于single-sign-on - 具有SAML,Keycloak和Nextcloud的SSO,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48400812/
在下面的方法中,如何将第一个Single的结果传递给第二个Single? 如现在所写,当它返回时,somethingId 是空的。如果我将返回的 Single.just(somethingId) 中的
我发现很多帖子都在回答类似的问题(例如“如何用 / 替换 \”或“如何替换 \\” by \”。我理解所有这些,但没有一个能解决我的特殊问题。这里是: 我正在从注册表中读取路径字符串,其中包含“///
注意:事实证明,toCompletable() 并非错误,而是调用代码。调用代码使得更改此方法使其工作(或不工作)。 我有以下方法。它返回一个 Single。有用。执行内部代码,以便 remoteDa
react-native repo here 中的一个文件中有一段代码如下图: export type Operation = & {instanceID: DebugID} & (
当使用带有 Single() 的 LINQ 时,我的代码行总是带有绿色下划线,并带有建议“替换为对 single 的单一调用”。这是什么意思?下面是产生该建议的一行代码示例: var user = d
讨论来自 this answer让我好奇。哪个更快: someEnumerable.Single(predicate); 或 someEnumerable.Where(predicate).Singl
我正在使用 Keycloak 作为单点登录 (SSO) 平台的 OP。我已经将我的两个 Web 应用程序连接到 Keycloak,以便使用单点登录功能。 此外,我已经制作了一个应用程序,当注销时将被重
我的步骤是: 创建单个值 x - 可能会占用一些 CPU 资源 使用值x来执行IO操作。这已经返回 Completable 返回x 所以我想这样做: Single result =
我想知道是否有人可以阐明这个问题,什么时候使用 Single.fromCallable( ()-> myObject ) 代替 Single.just(myObject) 根据文档,Single.fr
我有两个 Singles 来源,我将它们组合成一个 Single of Pair。 假设我们对这些来源有两种方法: private Single single1() {} private Single
我想将单个 Intel CPU 内核的速度与单个 nVidia GPU 内核的速度(即:单个 CUDA 代码、单个线程)进行比较。我确实实现了以下简单的二维图像卷积算法: void convoluti
我在实现 Ping Federate 时遇到此问题 Error - Single Sign-On Single sign-on authentication was unsuccessful (ref
我有几个 api 调用(Rx singles),我想将它们组合成一个 Single。我正在使用 Single.merge 尝试合并这些调用的结果,但是当我订阅响应时,我得到一个空数组,因为订阅已经发生
早上好。我的代码有问题 bootsfaces 。我需要我的 DataTable 支持单行选择,但不支持多行选择。但是,我的表格始终只使用多项选择。 这是我的代码: 我没有进行简单的选择,因为我引用了
我怎样才能像下面的代码那样使用字符串。 $str = 'Is yo"ur name O'reil"ly?'; 上面的代码只是一个例子..我需要使用包含单引号和双引号的大 html 模板。我尝试了 Ad
我有一组地理空间+时间数据和一些附加属性,我将在 map 上显示这些数据。该集合目前有几百万份文件,并且会随着时间的推移而增加。 每个文档都有以下字段: 位置:[geojson 对象] 日期:[日期对
我目前在 .NET 2.0 下使用 SharpZipLib,通过它我需要将单个文件压缩为单个压缩存档。为此,我目前正在使用以下内容: string tempFilePath = @"C:\Users\
我有 table create table1( column1 number(10, column2 number(10), column3 number(10) ); column1是主
考虑下面这段代码,我正在尝试使用 Executors.newFixedThreadPool(1).asCoroutineDispatcher()创建单线程调度程序;我想要 launch(singleT
我面临着困惑,举个例子 4 Single: val s1 : Single = service1.execute().subscribeOn(io()) val s2 : Single = servi
我是一名优秀的程序员,十分优秀!