forked from sonic-net/sonic-buildimage
-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[dns] Add support for static DNS configuration. (sonic-net#14549)
- Why I did it Add support for static DNS configuration. According to sonic-net/SONiC#1262 HLD. - How I did it Add a new resolv-config.service that is responsible for transferring configuration from Config DB into /etc/resolv.conf file that is consumed by various subsystems in Linux to resolve domain names into IP addresses. - How to verify it Run the image compilation. Each component related to the static DNS feature is covered with the unit tests. Run sonic-mgmt tests. Static DNS feature will be covered with the system tests. Install the image and run manual tests.
- Loading branch information
1 parent
7a6d3ce
commit fb0bafd
Showing
19 changed files
with
167 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
[Unit] | ||
Description=Update DNS configuration | ||
Requires=updategraph.service | ||
After=updategraph.service | ||
BindsTo=sonic.target | ||
After=sonic.target | ||
StartLimitIntervalSec=0 | ||
|
||
[Service] | ||
Type=oneshot | ||
RemainAfterExit=yes | ||
ExecStart=/usr/bin/resolv-config.sh start | ||
|
||
[Install] | ||
WantedBy=sonic.target |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
#!/bin/bash | ||
|
||
WD=/var/run/resolvconf/ | ||
CONFIG_DIR=${WD}/interface/ | ||
STATIC_CONFIG_FILE=mgmt.static | ||
DYNAMIC_CONFIG_FILE_TEMPLATE=*.dhclient | ||
|
||
update_symlink() | ||
{ | ||
ln -sf /run/resolvconf/resolv.conf /etc/resolv.conf | ||
} | ||
|
||
start() | ||
{ | ||
update_symlink | ||
|
||
redis-dump -d 4 -k "DNS_NAMESERVER*" -y > /tmp/dns.json | ||
if [[ $? -eq 0 && "$(cat /tmp/dns.json)" != "{}" ]]; then | ||
# Apply static DNS configuration and disable updates | ||
/sbin/resolvconf --disable-updates | ||
pushd ${CONFIG_DIR} | ||
# Backup dynamic configuration to restore it when the static configuration is removed | ||
mv ${DYNAMIC_CONFIG_FILE_TEMPLATE} ${WD} || true | ||
|
||
sonic-cfggen -d -t /usr/share/sonic/templates/resolv.conf.j2,${STATIC_CONFIG_FILE} | ||
|
||
/sbin/resolvconf --enable-updates | ||
/sbin/resolvconf -u | ||
/sbin/resolvconf --disable-updates | ||
popd | ||
else | ||
# Dynamic DNS configuration. Enable updates. It is expected to receive configuraution for DHCP server | ||
/sbin/resolvconf --disable-updates | ||
pushd ${CONFIG_DIR} | ||
rm -f ${STATIC_CONFIG_FILE} | ||
# Restore dynamic configuration if it exists | ||
mv ${WD}/${DYNAMIC_CONFIG_FILE_TEMPLATE} ${CONFIG_DIR} || true | ||
|
||
/sbin/resolvconf --enable-updates | ||
/sbin/resolvconf -u | ||
fi | ||
} | ||
|
||
clean-dynamic-conf() | ||
{ | ||
rm -f ${WD}/${DYNAMIC_CONFIG_FILE_TEMPLATE} | ||
rm -f ${WD}/postponed-update | ||
} | ||
|
||
case $1 in | ||
start) | ||
start | ||
;; | ||
cleanup) | ||
clean-dynamic-conf | ||
;; | ||
*) | ||
echo "Usage: $0 {start|clean-dynamic-conf}" | ||
exit 2 | ||
;; | ||
esac |
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
# Dynamic resolv.conf(5) file generated by resolvconf(8) | ||
# The content of this file may be overwritten during a config reload. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
{% for ip in DNS_NAMESERVER|sort %} | ||
nameserver {{ ip }} | ||
{% endfor -%} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
#!/bin/bash | ||
|
||
for container in $(docker ps -a --format=" {{ .ID }}"); do | ||
docker cp -L /etc/resolv.conf ${container}:/_resolv.conf | ||
docker exec -t ${container} bash -c "cat /_resolv.conf > /etc/resolv.conf" | ||
docker exec -t ${container} bash -c "rm /_resolv.conf" | ||
done |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
nameserver 1.1.1.1 | ||
nameserver 2001:4860:4860::8888 | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
{ | ||
"DNS_NAMESERVER": { | ||
"1.1.1.1": {}, | ||
"2001:4860:4860::8888": {} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters