maintenance:general:tools:net_setup.pl
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
maintenance:general:tools:net_setup.pl [2020/11/23 16:05] – [Capabilities] yspeerte | maintenance:general:tools:net_setup.pl [2024/07/03 12:31] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
+ | {{indexmenu_n> | ||
+ | ====== net_setup.pl ====== | ||
+ | The '' | ||
+ | |||
+ | The intention of the script is to make the networking setup as smooth as possible, limiting the possibility of errors by manipulating the configurations by hand. It will not allow networking configurations that are not directly supported by the NetYCE appliance. | ||
+ | |||
+ | The net_setup script will not just setup the networking, it also creates and maintains a NetYCE networking configuration file that is used to configure NetYCE various components and daemons. It gathers information from the system and from the user to write the settings to the system and to setting files of netYCE. | ||
+ | |||
+ | |||
+ | ==== Capabilities ==== | ||
+ | |||
+ | The '' | ||
+ | |||
+ | The net_setup supports various settings that can be categorized covering these topics and capabilities: | ||
+ | |||
+ | * Setting ' | ||
+ | * Hostname and domain name changes | ||
+ | * Multiple ethernet interfaces | ||
+ | * IPv4 supported on CentOS 6.x and CentOS/ | ||
+ | * IPv6 supported on CentOS/ | ||
+ | * IPv4 + IPv6 dual-stack and IPv6-only configurations | ||
+ | * Configure secondary addresses (IPv4 and IPv6) | ||
+ | * DNS server configuration (IPv4 and IPv6) | ||
+ | * Static (fixed) or DHCP (autoconf) ip-addresses | ||
+ | * Automatic detection and NetYCE reconfiguration on DHCP ip-address change (IPv4 and IPv6) | ||
+ | * Default gateway interface assignment and routing configuration | ||
+ | * NetYCE user and devices interface identification | ||
+ | * External NAT address assignment for Network devices | ||
+ | * NTP server assignment (date and time sync) | ||
+ | |||
+ | <color red> | ||
+ | |||
+ | > The net_setup script needs to be started as ' | ||
+ | |||
+ | > In the dialog with net_setup the (default) values and the user entries are shown using the color '< | ||
+ | |||
+ | > Default values are shown between square brackets ('' | ||
+ | |||
+ | > At each prompt a help message is available by entering the '' | ||
+ | |||
+ | |||
+ | ==== ' | ||
+ | |||
+ | The configured and collected networking data net_setup uses is written to: ''/ | ||
+ | |||
+ | The net_setup script requires execution as the ' | ||
+ | |||
+ | |||
+ | ==== Invocation ==== | ||
+ | |||
+ | Execution of net_setup.pl is preferably done using a server console session. The activation of new network settings could result in a lost session resulting in an incomplete setup, or should the new network settings result in an unreachable server the console is the only means to correct it anyway. See the section on [[maintenance: | ||
+ | |||
+ | Therefore the net_setup.pl script is part of the ' | ||
+ | |||
+ | < | ||
+ | -- as root: | ||
+ | # / | ||
+ | |||
+ | -- as yce: | ||
+ | $ sudo / | ||
+ | </ | ||
+ | |||
+ | ==== ' | ||
+ | |||
+ | The net_setup script is part of the ' | ||
+ | |||
+ | < | ||
+ | -- NetYCE Networking setup | ||
+ | Hit enter within 5 seconds to start setup ..... | ||
+ | </ | ||
+ | |||
+ | < | ||
+ | -- NetYCE Networking setup | ||
+ | Hit enter within 5 seconds to start setup | ||
+ | -- Timeout, skipping setup | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==== Setting passwords ==== | ||
+ | |||
+ | Because of its use at the initial ' | ||
+ | |||
+ | < | ||
+ | -- NetYCE Networking setup | ||
+ | Hit enter within 5 seconds to start setup .. | ||
+ | |||
+ | NOTE: | ||
+ | When prompted for input help on the question is available by entering '?' | ||
+ | Incorrect responses result in a message on the expect input. | ||
+ | Just hitting < | ||
+ | The proces can be aborted at any prompt by entering ' | ||
+ | |||
+ | good, root privileges apply | ||
+ | -- System release | ||
+ | | ||
+ | using setup for Redhat V7 | ||
+ | -- Read Network setup: '/ | ||
+ | -- Read NetYCE setup: '/ | ||
+ | -- Setup passwords | ||
+ | |||
+ | For the first-time setup it is mandatory to set the ' | ||
+ | prompted now to enter the desired root password twice. This will then be the | ||
+ | active ' | ||
+ | |||
+ | enter ' | ||
+ | | ||
+ | | ||
+ | |||
+ | For the first-time setup it is mandatory to set the ' | ||
+ | prompted now to enter the desired yce password twice. This will then be the | ||
+ | active ' | ||
+ | |||
+ | enter ' | ||
+ | | ||
+ | | ||
+ | </ | ||
+ | |||
+ | Once the passwords are set, the forced password prompts will be replaced for optional password setting prompts. | ||
+ | |||
+ | < | ||
+ | -- Setup passwords | ||
+ | Set the ' | ||
+ | Set the ' | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==== Change hostname ==== | ||
+ | |||
+ | The next prompt relates to changing the hostname and the domain of the server. The hostname change will be activated at the same time as the network changes are activated. | ||
+ | |||
+ | < | ||
+ | -- Setup hostname | ||
+ | Full qualified name is ' | ||
+ | Is this full name correct? | ||
+ | |||
+ | The displayed full-qualified-domain-name should match the hostname and domain | ||
+ | of this server and must be unique. Type ' | ||
+ | ' | ||
+ | |||
+ | Is this full name correct? | ||
+ | | ||
+ | DNS domain? | ||
+ | Full qualified name is ' | ||
+ | Is this full name correct? | ||
+ | name change: ' | ||
+ | Save this configuration? | ||
+ | | ||
+ | </ | ||
+ | |||
+ | ==== Interface configuration ==== | ||
+ | |||
+ | Prior to prompting for the interface configuration settings, the existing - operational - interface settings are read from the system and presented in a concise table per ethernet interface. Non-ethernet interfaces are ignored. | ||
+ | |||
+ | The example below shows this interface summary of a system deploying two interfaces, one using fixed IP-addresses, | ||
+ | |||
+ | {{: | ||
+ | |||
+ | When selecting the default [yes], the user enters a set of dialog prompts for the first interface. When those are done confirmation is requested if the entries are correct and the dialog moves to the next interface. Should mistakes have been mode, the same interface is re-prompted. | ||
+ | |||
+ | The first prompt determines the basic way the interface will be setup: | ||
+ | < | ||
+ | | ||
+ | -- Setup interface ' | ||
+ | | ||
+ | |||
+ | Each ethernet interface can use a configuration method that is either | ||
+ | ' | ||
+ | not used: ' | ||
+ | |||
+ | | ||
+ | </ | ||
+ | |||
+ | When the interface is not to be disabled (' | ||
+ | |||
+ | A sample session where the static IPv4-address is changed. Note that the gateway address is automatically calculated from the prefix. | ||
+ | < | ||
+ | -- Setup interface ' | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | |||
+ | Using the assigned ip-address and the prefix the network-address is | ||
+ | determined. The first address of the network-address is usually the gateway | ||
+ | address used, although any address in the subnet may be used. The default | ||
+ | is calculated as indicated. Type ' | ||
+ | assigned (not recommended). | ||
+ | |||
+ | | ||
+ | | ||
+ | | ||
+ | </ | ||
+ | |||
+ | The dialog continues for the IPv6 setup and concludes with the DNS server addresses that will be used. | ||
+ | < | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | </ | ||
+ | |||
+ | The DNS servers may use IPv4 and IPv6 addresses, but when completed a validation will check if the DNS addresses can be used by the IP-versions used. | ||
+ | |||
+ | The dialog for DHCP setup is more limited. It is not possible to setup an interface where IPv4 is static and IPv6 uses dhcp or vice versa. And, although dual-stack is currently quite normal, IPv6-only configurations are supported. | ||
+ | < | ||
+ | -- Setup interface ' | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | |||
+ | When using IPv6 Autoconf an IPv6 address will be generated using the Router Advertisement (RA). | ||
+ | |||
+ | | ||
+ | | ||
+ | | ||
+ | |||
+ | The DHCP server usually configures the DNS servers the system will use. The | ||
+ | optional IPv4/ | ||
+ | by the DHCP. Type ' | ||
+ | |||
+ | | ||
+ | | ||
+ | </ | ||
+ | |||
+ | When the interface dialogs are completed, the updated interface setup summary is displayed again along with a prompt to save it in the net_update.conf settings file. | ||
+ | |||
+ | ==== Interface roles ==== | ||
+ | |||
+ | NetYCE can assign different roles to the various interfaces. If only one (ethernet) interface is present all roles are automatically assigned to the one interface and the dialog is skipped. | ||
+ | |||
+ | {{: | ||
+ | |||
+ | Three roles must currently assigned to the available ethernet interfaces. First there is the (default) " | ||
+ | |||
+ | The remaining roles are NetYCE specific. The " | ||
+ | |||
+ | The final role defines the interface to communicate with the network devices. For the incoming connections from the network devices, optional NAT addresses can be configured for IPv4 and IPv6. Most file transfers between NetYCE servers and the network devices must originate from the device and must be able to connect to the server using its address. When there is an address translation service (NAT) active, the devices must use the external addresses instead. These addresses are configured here when needed. | ||
+ | |||
+ | < | ||
+ | -- Setup default-gateway interface | ||
+ | 1) enp0s17 | ||
+ | 2) enp0s8 | ||
+ | | ||
+ | | ||
+ | -- Setup user front-end interface | ||
+ | 1) enp0s17 | ||
+ | 2) enp0s8 | ||
+ | users interface (ipv4 and ipv6)? | ||
+ | | ||
+ | -- Setup network-devices interface | ||
+ | 1) enp0s17 | ||
+ | 2) enp0s8 | ||
+ | | ||
+ | | ||
+ | | ||
+ | |||
+ | File transfers between NetYCE and devices require a connection to be | ||
+ | initiated from the device to NetYCE. If the NATted address address the | ||
+ | devices must use is different from the ip-address of the interface, | ||
+ | specify it here. Otherwise use ' | ||
+ | |||
+ | | ||
+ | | ||
+ | </ | ||
+ | |||
+ | The above session example shows a two-interface setup where one interface (enp0s17) uses fixed ip-addresses for both the user and the device communication, | ||
+ | |||
+ | |||
+ | An additional prompt to define NTP source for the systems real-time-clock is also included here. Optionally the ' | ||
+ | |||
+ | < | ||
+ | -- Setup clock-synchronization | ||
+ | Use ' | ||
+ | ntp server address? | ||
+ | </ | ||
+ | |||
+ | When satisfied confirm on the ' | ||
+ | The networking setup then continues to activate this configuration. Should the net_setup not have been invoked as root or with sudo, the network activation is skipped and only the NetYCE re-configuration is executed. | ||
+ | |||
+ | |||
+ | ==== Network activation ==== | ||
+ | |||
+ | After confirming the updated configuration, | ||
+ | |||
+ | < | ||
+ | -- Generating network configuration files | ||
+ | -- Updating interface configurations | ||
+ | | ||
+ | | ||
+ | -- Updating network config file | ||
+ | | ||
+ | -- Updating dns resolv config | ||
+ | | ||
+ | -- Updating hostname config | ||
+ | | ||
+ | | ||
+ | | ||
+ | no hostname change: ' | ||
+ | | ||
+ | -- Installing ' | ||
+ | -- Activating network | ||
+ | | ||
+ | </ | ||
+ | |||
+ | Then the network must be restarted. As a network restart could very well affect the existing network sessions (due to new address or routing), the user could find his session terminated at this point. | ||
+ | |||
+ | Although activation could have continued, the user will be unable to observe it and will timeout after a few minutes. If the session was not impacted, the user will be able to monitor the activation and the subsequent re-configuration of the NetYCE application. | ||
+ | |||
+ | < | ||
+ | -- Activating network | ||
+ | | ||
+ | | ||
+ | | ||
+ | no hostname change: ' | ||
+ | | ||
+ | |||
+ | Active roles: | ||
+ | Gateway | ||
+ | | Interface | ||
+ | | ||
+ | | IPv4 | IPv6 | ||
+ | | ||
+ | Users | ||
+ | | Interface | ||
+ | | ||
+ | | IPv4 | IPv6 | ||
+ | | ||
+ | Devices | ||
+ | | Interface | ||
+ | | ||
+ | | IPv4 | IPv6 | ||
+ | | ||
+ | | IPv4 nat | IPv6 nat | ||
+ | | ||
+ | |||
+ | </ | ||
+ | |||
+ | Because of this ambiguous behaviour it is advised to execute potentially session disrupting network modifications using the //server console//. This is also good practice as incorrect network settings might result in an unreachable server. The console is then the only means to correct the network settings. | ||
+ | |||
+ | If the session-lost issue was experienced it is recommended to re-execute the net_setup after a new communication session was established. Because the basic network is now setup properly, the entire setup procedure can be executed without interruption. Just confirm the prompts which should all reflect the earlier choices, and the system will re-activate correspondingly. | ||
+ | |||
+ | |||
+ | ==== NetYCE re-activation ==== | ||
+ | |||
+ | When the net_setup completes it will automatically execute the '' | ||
+ | |||
+ | When setting up a new NetYCE server, the NetYCE configuration will use defaults which will still require manual session to properly setup the application. | ||
+ | |||
+ | Please refer to the article on the [[maintenance: | ||
+ | |||
+ | Below example output of a yce_setup session using the regenerate ('' | ||
+ | |||
+ | < | ||
+ | -- Generating and activating NetYCE | ||
+ | |||
+ | -- ---------------------------------------- | ||
+ | -- Starting ' | ||
+ | -- System release | ||
+ | | ||
+ | using setup for Redhat V7 | ||
+ | -- Connected to database at ' | ||
+ | |||
+ | Current setup: | ||
+ | devel7a.netyce.org (*) | ||
+ | | IP-address | ||
+ | | users | 172.17.10.24 | ||
+ | | Database | ||
+ | | id=1 | ||
+ | devel7b.netyce.org | ||
+ | | IP-address | ||
+ | | users | 172.17.10.25 | ||
+ | | Database | ||
+ | | id=2 | ||
+ | local server is marked with (*) | ||
+ | -- Create configs for server ' | ||
+ | -- Yce: / | ||
+ | -- Retrieving file-transfer configurations... | ||
+ | can support ' | ||
+ | can support ' | ||
+ | can support ' | ||
+ | can support ' | ||
+ | -- Mojo: / | ||
+ | mojo url set to ' | ||
+ | wiki url set to ' | ||
+ | -- Yce_psmon: / | ||
+ | -- Crontab: / | ||
+ | -- Httpd: / | ||
+ | -- Mysql: / | ||
+ | mysql version is ' | ||
+ | mysql key_buffer set to ' | ||
+ | mysql tmpdir set to '/ | ||
+ | -- Updating ' | ||
+ | | ||
+ | | ||
+ | | ||
+ | | ||
+ | -- Renewing NMS table permissions | ||
+ | -- Checking database replication | ||
+ | | ||
+ | -- Updating config-sync setup | ||
+ | | ||
+ | | ||
+ | -- Relaunching NetYCE daemons... | ||
+ | -- yce_psmon: 18813 | ||
+ | stop: /bin/sudo / | ||
+ | wait stop ' | ||
+ | | ||
+ | wait start ' | ||
+ | -- yce_netmon: 20081 | ||
+ | stop: / | ||
+ | wait stop ' | ||
+ | | ||
+ | wait start ' | ||
+ | -- yce_cramer: | ||
+ | # ignored: / | ||
+ | -- yce_tftpd: 18933 | ||
+ | stop: /bin/sudo / | ||
+ | wait stop ' | ||
+ | | ||
+ | wait start ' | ||
+ | -- yce_skulker: | ||
+ | # ignored: / | ||
+ | -- yce_sched: 18956 | ||
+ | stop: / | ||
+ | wait stop ' | ||
+ | | ||
+ | wait start ' | ||
+ | -- yce_nccmd: 18976 | ||
+ | stop: / | ||
+ | wait stop ' | ||
+ | wait stop ' | ||
+ | | ||
+ | wait start ' | ||
+ | -- yce_ibd: | ||
+ | # disabled | ||
+ | -- morbo: | ||
+ | # disabled | ||
+ | -- mojo: 18985 25379 26425 28340 28564 28565 28566 | ||
+ | mojo hot-deploy on pid 18985 | ||
+ | | ||
+ | -- yce_xch: 19034 | ||
+ | stop: / | ||
+ | wait stop ' | ||
+ | | ||
+ | wait start ' | ||
+ | |||
+ | -- Completed | ||
+ | |||
+ | </ | ||
+ | |||
+ | |||
+ | ==== Dynamic (DHCP) addresses ==== | ||
+ | |||
+ | The NetYCE application supports dynamic IP-addresses using DHCP (and autoconf for IPv6 too). This implies that the various NetYCE components must dynamically be re-configured when an IP-address is allocated or changed. | ||
+ | |||
+ | If the **net_setup** has interfaces configured for DHCP, the **yce_setup** will automatically configure and launch the '' | ||
+ | |||
+ | If the DHCP server is slow to issue an IP-address, the NetYCE application might take several minutes to properly activate itself. Should the DHCP server fail to issue an address, the NetYCE application will not function. | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | // |