Oracle11gR2 On Asianux3集群部署指南(64bit)
目录 Oracle11gR2 On Asianux3 集群部署指南 ... 5 1 前言 ... 5 1.1 说明 ... 5 1.2 安装软件清单 ... 5 2 准备工作 ... 5 2.1 部署环境描述 ... 5 2.1.1 部署服务器环境描述 ... 5 2.1.2 RAC 体系结构 ... 5 2.1.3 RAC 网络分配 ... 6 2.2 检查网卡 ... 7
目录
Oracle11gR2 On Asianux3集群部署指南... 5
1前言... 5
1.1 说明... 5
1.2 安装软件清单... 5
2准备工作... 5
2.1 部署环境描述... 5
2.1.1部署服务器环境描述... 5
2.1.2 RAC体系结构... 5
2.1.3 RAC网络分配... 6
2.2 检查网卡... 7
2.3 修改IP.. 7
2.4 修改主机名... 8
2.5 修改/etc/hosts文件... 9
2.6 跳过DNS配置... 9
2.7 添加oracle和grid用户和用户组... 10
2.8 修改oracle和grid环境变量... 11
2.8.1 Grid用户环境变量... 11
2.8.2 Oracle用户环境变量... 11
2.9 创建路径和授权... 11
2.10 修改登录oracle和gird用户的资源数... 12
2.10.1修改登录限制文件... 12
2.10.2修改验证登录配置文件... 12
2.11 停止NTP服务... 12
2.12 配置Oracle和Grid用户ssh对等性... 13
2.12.1验证ssh对等性... 13
2.13 磁盘规划... 13
2.13.1创建共享磁盘... 13
2.13.2共享磁盘授权... 13
2.14 解压安装介质... 14
3安装grid(网格)软件... 14
4安装数据库软件... 26
5创建数据库实例... 32
6安装问题集... 39
Oracle11gR2 On Asianux3集群部署指南
1 前言
1.1 说明
-
本文档内容讲述Oracle 11.2.0.5 on Asianux 3.0 4.1.2-50 (64bit)集群基本安装步骤和方法。文档内容已在实际环境中部署、验证。
-
使用本文档,需具备ORACLE和LINUX基础知识。
1.2 安装软件清单
本指南用到的软件清单:
-
Asianux 3.0 4.1.2-50
-
linux.x64_11gR2_database_1of2
-
linux.x64_11gR2_database_2of2
-
linux.x64_11gR2_grid
2 准备工作
若无特别说明,“$”提示符均表示在oracle用户下执行,“#”提示符均表示在root用户下执行。
2.1 部署环境描述
2.1.1 部署服务器环境描述
服务器名 项目名称 |
服务器1 |
服务器2 |
主机名 |
rac1 |
rac2 |
物理内存 |
4GB |
4GB |
磁盘 |
30GB |
30GB |
共享磁盘 |
20GB |
2.1.2 RAC体系结构
两台服务器,划了一块共享磁盘,每台服务器需要三个IP,两台服务器通过心跳线通讯,共同访问共享磁盘的信息,对外提供虚拟IP给外部客户端访问者。
2.1.3 RAC网络分配
公共IP是网卡的IP可以提供给远程连接,虚拟IP提供远程连接,还有可以实现漂移功能,当一个节点故障时虚拟IP会自动漂移到健康的节点,私有IP是内部通讯使用的心跳线,Scan IP是11g开始出现的,相当于在客户端和数据库之间增加一层虚拟的网络服务层,需要安装配置DNS服务器,在后面安装grid软件会用到Scan IP所以必须规划好,但这个Scan IP不是必须要用到,主要作用是为了方便维护数据库客户端连接文件tnsnames.ora。
主机名 |
类型 |
IP |
网络接口 |
说明 |
rac1 |
Public IP |
192.168.13.120 |
eth0 |
公共 |
rac2 |
Public IP |
192.168.13.122 |
eth0 |
公共 |
rac1-vip |
Virtual IP |
192.168.13.121 |
eth0:1 |
虚拟 |
rac2-vip |
Virtual IP |
192.168.13.123 |
eth0:1 |
虚拟 |
rac1-priv |
Private IP |
10.10.10.11 |
eth1 |
私有 |
rac2-priv |
Private IP |
10.10.10.12 |
eth1 |
私有 |
scan-rac |
Scan IP |
192.168.13.124 |
eh0 |
配置DNS |
2.2 检查网卡
在两个节点的root用户下,执行ifconfig查看是否有两个网卡,如果可以看到eth0和eth1,则说明有两个网卡,如果只看到eth0则需要添加一个虚拟网卡,添加网卡在虚拟机上可以直接添加一个新的网卡或者可以在网上邻居上添加但前提是需要创建一个网卡文件在root用户下执行:
#cp /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/sysconfig/network-scripts/ifcfg-eth1
-
在虚拟机上添加选择以太网适配器,然后下一步即可添加虚拟网卡:
-
创建了eth1文件后,在网上邻居添加网卡:
2.3 修改IP
在两个节点的root用户下,执行vi /etc/sysconfig/network-scripts/ifcfg-eth0修改网卡1的IP,执行vi /etc/sysconfig/network-scripts/ifcfg-eth1修改网卡2的IP或者直接进入两个节点服务器中通过网上邻居去修改IP和网关,子网掩码,修改完成需要重启网络服务,在两个节点的root用户下执行命令:service network restart。
节点1的网卡1:
节点1的网卡2:
2.4 修改主机名
在两个节点的root用户下,执行vi /etc/sysconfig/network,修改主机名
节点1主机名修改成rac1,节点2主机名修改成rac2。修改完成,需要重启服务,在两个节点的root用户下执行命令:service network restart,重启服务后,重新打开窗口即可看到修改的新的主机名。
节点1的主机名:
重启服务:
2.5 修改/etc/hosts文件
hosts文件是DNS解析用的,后面的网格,数据库软件安装,实例安装过程中都会通过hosts文件获取IP和主机名,是必须要修改,在两个节点的root用户下,执行vi /etc/hosts。
2.6 跳过DNS配置
在2.1.3中有提到SCAN IP,要用到SCAN IP需要安装DNS服务器,这个功能并不是必须的,可以修改一些参数来跳过网格软件安装时候的DNS校验,如果不做这一步,装网格软件完成时候会提示一个错误信息“[INS-20802] oracle cluster verification实用程序失败”的错误信息,这个错误忽略,但为了不出现报错信息需要跳过DNS校验。需要先重命名nslookup(它是二进制文件打开会乱码,必须先重命名),然后再新建一个nslookup,在两个节点的root用户下:
-
重命名:mv /usr/bin/nslookup /usr/bin/nslookup.original
-
新建:vi /usr/bin/nslookup,加入代码:
#!/bin/bash
HOSTNAME=${1}
if [[ $HOSTNAME = "scan-rac" ]]; then
echo "Server: 192.168.13.125"
echo "Address: 192.168.13.125#53"
echo "Non-authoritative answer:"
echo "Name: scan-rac"
echo "Address: 192.168.13.124"
else
/usr/bin/nslookup.original $HOSTNAME
fi
网格安装在设置阶段提示的错误信息:
2.7 添加oracle和grid用户和用户组
在两个节点的root用户下,添加oracle和grid用户和用户组
groupadd -g 1000 oinstall
groupadd -g 1300 dba
groupadd -g 1301 oper
groupadd -g 1200 asmadmin
groupadd -g 1201 asmdba
groupadd -g 1202 asmoper
useradd -u 1101 -g oinstall -G asmadmin,asmdba,asmoper,dba grid
useradd -u 1100 -g oinstall -G dba,oper,asmdba oracle
passwd grid
passwd oracle
检查oracle和grid用户的组创建情况在root用户下输入id oracle即可查看oracle用户的建组情况,id grid查看grid用户的建组情况。
2.8 修改oracle和grid环境变量
2.8.1 Grid用户环境变量
在两个节点的grid用户下,执行vi .bash_profile,修改grid的环境变量,执行source .bash_profile,可载入刚刚设置的环境变量
添加代码(节点2的SID修改成+ASM2):
export ORACLE_SID=+ASM1
export ORACLE_BASE=/u01/app/grid
export ORACLE_HOME=/u01/grid
export PATH=$ORACLE_HOME/bin:$PATH
2.8.2 Oracle用户环境变量
在两个节点的oracle用户下,执行vi .bash_profile,修改oracle的环境变量,执行source .bash_profile,可载入刚刚设置的环境变量
添加代码(节点2把SID修改成dw2):
export ORACLE_SID=dw1
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=/u01/app/oracle/11.2.0
export PATH=$ORACLE_HOME/bin:$PATH
2.9 创建路径和授权
在两个节点的root用户下,执行如下操作:
mkdir -p /u01/app/grid
mkdir -p /u01/app/oracle
mkdir -p /u01/grid
chown grid:oinstall /u01/app/grid
chown oracle:oinstall /u01/app/oracle
chown grid:oinstall /u01/app
chown grid:oinstall /u01/grid
chmod -R 755 /u01
chmod -R 775 /u01/app
2.10 修改登录oracle和gird用户的资源数
2.10.1 修改登录限制文件
在两个节点的root用户下,执行vi /etc/security/limits.conf,添加如下代码:
oracle soft nofile 65536
oracle hard nofile 65536
oracle soft nproc 16384
oracle hard nproc 16384
grid soft nproc 2047
grid hard nproc 16384
grid soft nofile 1024
grid hard nofile 65536
2.10.2 修改验证登录配置文件
在两个节点的root用户下,执行vi /etc/pam.d/login,添加如下代码:
session required pam_limits.so multiple open
2.11 停止NTP服务
停止NTP服务是在Oracle11R2中新增的检查项,在11gR2版本中,oracle新推出了自己的时间同步服务(CTSS),这只在一个集群所有节点中有效,与其他系统的时间并不同步,要使用CTSS同步时间,必须停止并清除NTP服务。
在两个节点的root用户下,执行如下命令:
[root@rac1 ~]# service ntpd status
ntpd is stopped
[root@rac1 ~]# chkconfig ntpd off
[root@rac1 ~]# cp /etc/ntp.conf /etc/ntp.conf.bak
[root@rac1 ~]# rm -rf /etc/ntp.conf
2.12 配置Oracle和Grid用户ssh对等性
在使用linux时候,有时候需要远程到一台主机的命令行窗口,通常我们都是用ssh的方式,但出于安全性考虑每次登陆都会被要求输入用户名和密码,为了避免麻烦,我们必须在两台主机建立ssh等效性,在后面的安装grid软件、数据库软件、数据库实例的时候,也会用到scp远程复制的功能,这个功能就需要做ssh对等性。从 11g开始,ssh对等性连接已经可以在grid网格安装的时候实现,具体操作看网格软件安装过程。
2.13 磁盘规划
2.13.1 创建共享磁盘
在exsit5.5上添加共享磁盘,在rac1中添加20g的磁盘,磁盘置备选择“厚置备为零”,scsi控制器选择1:1,scsi总线共享选择“虚拟”。
2.13.2 共享磁盘授权
创建完后,在两个节点的root用户下,执行fdisk –l,查看添加的共享磁盘,根据oracle规定,这个共享磁盘必须要有660以上的权限。
对新增的共享磁盘/dev/sdb授权:chmod -R 765 /dev/sdb,但每次机器重启都会被系统回收权限,所以必须把授权加入到随机自启动文件中,在两个节点的root用户下执行vi /etc/rc.local,添加授权命令。
2.14 解压安装介质
在节点1把 Oracle Grid Infrastructure软件上传到/home/grid/software 目录。将 Oracle Database软件上传到/home/oracle/software目录。
以 grid 用户身份解压缩 Oracle Grid Infrastructure软件:
[grid@rac1 ~]$ mkdir -p /home/grid/software
[grid@rac1 ~]$ cd /home/grid/software
[grid@rac1 software]$ unzip linux.x64_11gR2_grid.zip
以 oracle 用户身份解压缩 Oracle Database软件:
[oracle@rac1 ~]$ mkdir -p /home/oracle/software
[oracle@rac1 software]$ unzip linux.x64_11gR2_database_1of2.zip
[oracle@rac1 software]$ unzip linux.x64_11gR2_database_2of2.zip
3 安装grid(网格)软件
①在rac1的grid用户下,进入grid软件解压的根目录下,执行./runInstaller,进入OUI界面。
②安装选项
选择安装和配置集群的网格基础结构。
③安装类型
选择高级安装。
④产品语言
默认会选择简体中文和英语。
⑤网格即插即用
集群名称和sacn名称填写scan-rac,在2.1.3RAC网络分配中有规划。
配置GNS不需要勾选。
⑥集群节点信息
这步需要做两个事情,一个是配置节点2的主机名和虚拟主机名,另一个是做ssh连接。
-
点击添加,加入rac2和rac2-vip。
-
点击ssh连接,需要输入grid的密码(创建grid用户时候的密码),点击设置后grid软件自动会建立ssh连接,连接完成会提示成功建立无口令ssh连接,但需要在各个节点的两个用户下做ssh对等性测试才算完成。
在rac1,rac2两个节点上分别执行下述命令。
在rac1的grid用户下:
[grid@rac1~]$ ssh rac1 date
[grid@rac1~]$ ssh rac2 date
[grid@rac1~]$ ssh rac1-priv date
[grid@rac1~]$ ssh rac2-priv date
节点1:
节点2:
执行完成后,点击连接,如果成功,则可以继续下一步。
⑦网络接口使用情况
eth0默认是公共的,无需选择,eth1选择专用。需要注意:两个节点的两个网卡的四个子网掩码都需要一致,不然会提示错误。
⑧存储选项
选择自动存储管理(ASM)。
⑨创建ASM磁盘组
磁盘组名:OCRDG,冗余选择“外部”,如果看不到刚刚前面添加的共享磁盘,需要在右下角的更改搜索路径中,输入/dev/sdb(在root用户下,执行fdisk -l查看共享磁盘的磁盘路径)。
⑩ASM口令
选择对这些账户使用同一口令。
?故障隔离
选择IPMI。
?操作系统组
默认即可。
?安装位置
这里的路径是在2.8修改oracle和grid环境变量中设定的。
?创建产品清单
该目录需要有有775以上的权限,如果前面设置了环境变量,这里的路径默认是oracle基目录的上一级目录,/ORACLE_BASE/../,如果没有设置环境变量,这里默认的是home目录下面。
?先决条件检查
这里看到内核参数检查失败,这里和单机版本的oracle安装一样,点击“修补并再次检查(F)”按照提示执行脚本,再点击重新检查即可通过。
?概要
点击完成。
?设置
根据提示在两个节点上的root用户下分别执行两个脚本。
执行orainstRoot.sh,
执行root.sh,这个过程会提示输入路径,直接enter键默认路径即可。
?完成
安装完成后,检查集群的状态:
[root@rac1~]# su - grid
[grid@rac1~]$ crs_stat –t
4 安装数据库软件
在节点1的oracle用户下进入oracle解压根目录下,执行./runInstaller。
①配置安全更新
不勾选“我希望通过MY ORACLE SUPPORT接收安全更新”。
不填电子邮件。
②安装选项
选择“仅安装数据库软件”。
③网格选项
选择集群安装,全选两个集群;点击ssh连接,输入oracle的密码,点击设置,即可执行ssh等效性连接。
④产品语言
默认选择简体中文和英语。
⑤数据库版本
选择“企业版”。
⑥安装位置
这里会读取oracle环境变量设定的基目录和软件目录。
⑦概要
⑧安装产品
根据提示在两个节点的root用户下执行root.sh脚本。
⑨完成
5 创建数据库实例
在节点1的oracle用户下执行dbca创建数据库实例。
①选择数据库类型
选择RAC数据库。
②创建数据库
③选择一般用途或事务处理
④填写全局数据库名和选择节点
⑤配置企业管理器
这里不勾选,不需要安装EM。
⑥设置sys和system密码
⑦自动存储管理
⑧数据库恢复选项
不勾选,后续维护需要再开启。
⑨实例方案
不勾选,不需要用到。
⑩内存和字符集管理
内存默认物理内存的40%。
数据库字符集:AL32UTF8,国家字符集:AL16UTF16,默认语言:简体中文(Simplified Chinese),默认地区:中国(China)。
?数据库存储
有控制文件表空间数据文件重做日志的操作。这些后续可以再根据需要调整。
?创建完成
此安装过程需要30分钟到1小时。
最后如果出现了数据库创建完成的界面,实例创建完成,点击退出即可。
6 安装问题集
①问题:网络接口使用情况出现ins-41107错误;
解决:检查了rac1和rac2的IP设置和网关、子网掩码,发现rac1的子网掩码错误,修改后重启了网络服务重新即可进入。
②问题:在安装位置的时候提示“无法创建目录”;
解决:对节点1和节点2的基目录和软件安装目录授权,保持权限一致,都有755的权限。
③问题:多次安装集群和卸载会产生大量的日志;
解决:找到路径/oracle/app/oraInventory/logs,删除日志文件。
④问题:集群安装执行root.sh文件的时候提示,磁盘组ocrdg无法创建;
解决:给/dev/sdb授权,但每次重启机器权限都会回收,所以在linux的自动启动脚本/etc/rc.local写了一个开机自动授权的语句,给磁盘组授予660以上的权限。
⑤常出现的问题的情况:
a.执行用户出错,root和oracle、grid经常混淆;
b.编辑文件时候,空格、文件名出错;
c.执行只在单节点执行,没有同步在两个节点执行。
6、创建ASM磁盘标记出错或安装时能认到硬盘但是点击后磁盘的权限消失问题
[root@ora11g ~]# oracleasm createdisk -v VOL1 /dev/sdc1
Disk "VOL1" does not exist or is not instantiated
Writing disk header: done
Instantiating disk: oracleasm-instantiate-disk: Unable to create ASM disk "VOL1": Permission failed
Clearing disk header: done
原因:For pre-11.2.0.2 installations, SELinux must be disabled. For 11.2.0.2, SELinux is supported but the recommendation (if possible) is to run with SELinux disabled. See Bug 9746474.
上述告诉我们要关闭SeLinux设置。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

중국어 VSCode 설정: 전체 가이드 소프트웨어 개발에서 Visual Studio Code(줄여서 VSCode)는 일반적으로 사용되는 통합 개발 환경입니다. 중국어를 사용하는 개발자의 경우 VSCode를 중국어 인터페이스로 설정하면 작업 효율성이 향상될 수 있습니다. 이 기사에서는 VSCode를 중국어 인터페이스로 설정하는 방법을 자세히 설명하고 특정 코드 예제를 제공하는 완전한 가이드를 제공합니다. 1단계: 언어 팩을 다운로드하고 설치합니다. VSCode를 연 후 왼쪽을 클릭합니다.

Windows 11 출시와 함께 Microsoft는 VBS(Virtualization-basedSecurity)라는 보안 기능을 포함하여 몇 가지 새로운 기능과 업데이트를 도입했습니다. VBS는 가상화 기술을 활용하여 운영 체제와 중요한 데이터를 보호함으로써 시스템 보안을 향상시킵니다. 그러나 일부 사용자의 경우 VBS는 필수 기능이 아니며 시스템 성능에 영향을 미칠 수도 있습니다. 따라서 이 기사에서는 Windows 11에서 VBS를 끄는 방법을 소개합니다.

jQuery 참조 방법에 대한 자세한 설명: 빠른 시작 가이드 jQuery는 웹 사이트 개발에 널리 사용되는 JavaScript 라이브러리로, JavaScript 프로그래밍을 단순화하고 개발자에게 풍부한 기능을 제공합니다. 이 기사에서는 jQuery의 참조 방법을 자세히 소개하고 독자가 빠르게 시작할 수 있도록 구체적인 코드 예제를 제공합니다. jQuery 소개 먼저 HTML 파일에 jQuery 라이브러리를 도입해야 합니다. CDN 링크를 통해 소개하거나 다운로드할 수 있습니다.

Conda 사용 가이드: Python 버전을 쉽게 업그레이드하려면 특정 코드 예제가 필요합니다. 소개: Python 개발 프로세스 중에 새로운 기능을 얻거나 알려진 버그를 수정하기 위해 Python 버전을 업그레이드해야 하는 경우가 많습니다. 그러나 Python 버전을 수동으로 업그레이드하는 것은 문제가 될 수 있습니다. 특히 프로젝트와 종속 패키지가 상대적으로 복잡한 경우에는 더욱 그렇습니다. 다행스럽게도 뛰어난 패키지 관리자이자 환경 관리 도구인 Conda는 Python 버전을 쉽게 업그레이드하는 데 도움이 될 수 있습니다. 이 기사에서는 사용 방법을 소개합니다.

1. 소개 지난 몇 년 동안 YOLO는 계산 비용과 감지 성능 간의 효과적인 균형으로 인해 실시간 객체 감지 분야에서 지배적인 패러다임이 되었습니다. 연구원들은 YOLO의 아키텍처 설계, 최적화 목표, 데이터 확장 전략 등을 탐색하여 상당한 진전을 이루었습니다. 동시에 사후 처리를 위해 NMS(비최대 억제)에 의존하면 YOLO의 엔드투엔드 배포가 방해되고 추론 대기 시간에 부정적인 영향을 미칩니다. YOLO에서는 다양한 구성 요소의 설계에 포괄적이고 철저한 검사가 부족하여 상당한 계산 중복이 발생하고 모델 기능이 제한됩니다. 이는 최적이 아닌 효율성을 제공하며 성능 향상을 위한 상대적으로 큰 잠재력을 제공합니다. 이 작업의 목표는 사후 처리와 모델 아키텍처 모두에서 YOLO의 성능 효율성 경계를 더욱 향상시키는 것입니다. 이를 위해

ProxmoxVE에서 노드를 완전히 제거하고 클러스터에 다시 합류하는 시나리오 설명 ProxmoxVE 클러스터의 노드가 손상되어 신속하게 복구할 수 없는 경우 결함이 있는 노드를 클러스터에서 완전히 추방하고 잔여 정보를 정리해야 합니다. 그렇지 않으면 결함이 있는 노드가 사용하는 IP 주소를 사용하는 새 노드는 클러스터에 정상적으로 합류할 수 없습니다. 마찬가지로 클러스터에서 분리된 결함이 있는 노드가 복구된 후에는 클러스터와 관련이 없지만 이 단일 노드의 웹 관리에 액세스할 수 없습니다. 백그라운드에서 원래 ProxmoxVE 클러스터의 다른 노드에 대한 정보가 표시되므로 매우 짜증납니다. 클러스터에서 노드를 제거합니다. ProxmoxVE가 Ceph 하이퍼 수렴형 클러스터인 경우 호스트 시스템 Debian에서 클러스터의 모든 노드(삭제하려는 노드 제외)에 로그인하고 명령을 실행해야 합니다.

PHP7 설치 디렉토리 구성 안내서 PHP는 동적 웹 페이지를 개발하는 데 사용되는 널리 사용되는 서버측 스크립팅 언어입니다. 현재 PHP의 최신 버전은 PHP7입니다. 이 버전은 많은 새로운 기능과 성능 최적화를 도입했으며 많은 웹사이트와 애플리케이션에서 선호되는 버전입니다. PHP7을 설치할 때 설치 디렉터리를 올바르게 구성하는 것이 매우 중요합니다. 이 문서에서는 특정 코드 예제와 함께 PHP7 설치 디렉터리 구성에 대한 자세한 가이드를 제공합니다. PHP7을 먼저 다운로드하려면 PHP 공식 홈페이지(https://www.php7.kr)에서 다운로드해야 합니다.

PHP 웹 사이트를 성공적으로 배포하고 유지하려면 다음 단계를 수행해야 합니다. 웹 서버(예: Apache 또는 Nginx) 선택 PHP 설치 데이터베이스 생성 및 PHP 연결 서버에 코드 업로드 도메인 이름 및 DNS 모니터링 웹 사이트 유지 관리 설정 단계에는 PHP 및 웹 서버 업데이트, 웹 사이트 백업, 오류 로그 모니터링 및 콘텐츠 업데이트가 포함됩니다.
