Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
en:dpi:bras_bng:general_setup:start [2024/09/11 07:32] – [FastDPI L2 BRAS setup] elena.krasnobryzh | en:dpi:bras_bng:general_setup:start [Unknown date] (current) – removed - external edit (Unknown date) 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | ======General BRAS setup for L2/L3 modes====== | ||
- | {{indexmenu_n> | ||
- | |||
- | ===== FastDPI L3 BRAS setup ===== | ||
- | <note important> | ||
- | |||
- | 1. [[en: | ||
- | |||
- | < | ||
- | vi aslocal.txt | ||
- | 10.0.0.0/8 64512 | ||
- | 172.16.0.0/ | ||
- | 192.168.0.0/ | ||
- | cat aslocal.txt | as2bin / | ||
- | </ | ||
- | |||
- | <note important> | ||
- | |||
- | 2. Next, [[en: | ||
- | |||
- | < | ||
- | vi asnum.txt | ||
- | 64512 local | ||
- | cat asnum.txt | as2dscp / | ||
- | </ | ||
- | |||
- | 3. To enable authorization in **/ | ||
- | < | ||
- | enable_auth=1 | ||
- | </ | ||
- | |||
- | 4. Set the fastPCRF servers list: | ||
- | < | ||
- | auth_servers=127.0.0.1%lo: | ||
- | </ | ||
- | |||
- | The format for specifying a single server: '' | ||
- | FastDPI connects to the first available fastpcrf server from the list. | ||
- | |||
- | Do not forget to activate the [[en: | ||
- | < | ||
- | udr=1server | ||
- | </ | ||
- | |||
- | ==== IPv6 ==== | ||
- | In order to enable IPv6 addresses authorization you should activate the [[en: | ||
- | Actually, the Stingray SG authorizes a whole subnet with a predefined prefix length (by default it equals to /64) rather than particular individual IPv6 address. For example, if there are incoming packets sent from 2001:1::1 and 2001:1::10 addresses, only one of these addresses will be subject to authorization, | ||
- | |||
- | There is no analog of the '' | ||
- | |||
- | IPv6 authorization is automatically enabled if fastdpi.conf has: | ||
- | |||
- | < | ||
- | ipv6=1 | ||
- | enable_auth=1 | ||
- | </ | ||
- | |||
- | Starting from SSG version 8.1.4, it is possible to forcibly disable IPv6 address authorization by specifying in fastdpi.conf: | ||
- | < | ||
- | enable_auth_ipv6=0 | ||
- | </ | ||
- | |||
- | [[en: | ||
- | |||
- | ==== Implementing of the BRAS authorization ==== | ||
- | The process of implementing a new features is always a long and thorny path especially with regard to the BRAS authorization since it requires to configure not only the fastdpi/ | ||
- | |||
- | === Test bed === | ||
- | Simple and reliable way to implement the BRAS authorization is to organize a test bed. Pros: it will not affect the real subscribers. Cons: it requires the additional equipment. So it is not always possible to organize a full-fledged test bed. | ||
- | |||
- | === Separate autonomous system | ||
- | As described [[en: | ||
- | [[en: | ||
- | So the only IP addresses belonging to this local autonomous system will be authorized. " | ||
- | |||
- | === Diagnostic IP address === | ||
- | So the third approach is to define that the authorization should be performed just for the specified IP addresses. | ||
- | For this purpose there is the '' | ||
- | < | ||
- | The specified IP addresses must be local (i.e. these IP addresses should be within the autonomous system declared as local, please see above). | ||
- | If the '' | ||
- | |||
- | |||
- | ==== Authorization settings ==== | ||
- | You can specify the following authorization options in fastdpi.conf in addition to described [[en: | ||
- | |||
- | '' | ||
- | If the fastDPI doesn' | ||
- | |||
- | '' | ||
- | Zero value corresponds to unlimited authorization lifetime. | ||
- | This option is applied only in case the Radius response does not contain the '' | ||
- | Note that the Access-Reject also can contain the '' | ||
- | |||
- | :!: '' | ||
- | |||
- | '' | ||
- | |||
- | === Diagnostic settings === | ||
- | |||
- | '' | ||
- | Note that the authorization tracing significantly affects the performance of the fastDPI and causes the large number records being written to the logs, so it should not be enabled unless you have to. | ||
- | |||
- | '' | ||
- | Example: | ||
- | < | ||
- | This list can be applied at the authorization [[en: | ||
- | |||
- | |||
- | ===== FastDPI L2 BRAS setup ===== | ||
- | The activation of the fastDPI BRAS features is done according to **the mandatory settings** defined in the **fastdpi.conf** configuration file: | ||
- | * '' | ||
- | * '' | ||
- | * '' | ||
- | * '' | ||
- | |||
- | <note important> | ||
- | < | ||
- | udr=1 | ||
- | </ | ||
- | </ | ||
- | |||
- | **Example: | ||
- | <code bash> | ||
- | udr=1 | ||
- | auth_servers=127.0.0.1%lo: | ||
- | bras_enable=1 | ||
- | bras_arp_ip=192.168.1.255 | ||
- | bras_arp_mac=a0: | ||
- | </ | ||
- | |||
- | <note warning> | ||
- | |||
- | <note warning> | ||
- | |||
- | |||
- | ===== IPv6 Setup ===== | ||
- | L2 BRAS (BNG) supports allocating of stateful DHCPv6 IPv6 addresses. In this mode, IPv6-address is allocated to the subscriber with DHCPv6. Automated allocation of IPv6-addresses (SLAAC/ | ||
- | |||
- | The concept of the work scheme looks like this: | ||
- | - subscriber' | ||
- | - CPE sends a DHCPv6-request to obtain an IPv6-address; | ||
- | - DPI intercepts all DHCPv6 subscriber requests and processes them, in fact it is acting as a DHCPv6 server. If the DPI has no information on such subscriber or the session has expired, DHCPv6-request is transferred to Radius with PCRF; | ||
- | - PCRF receives a response from Radius. Among other parameters, it contains subscriber' | ||
- | - Having the data from PCRF, DPI sends a DHCPv6-response to the subscriber. DPI allocates one IPv6 address from the IPv6 prefix given to the subscriber, while the PD-prefix is transmitted to the subscriber completely. Despite that only one address is allocated from an IPv6-prefix, | ||
- | |||
- | <note warning> | ||
- | |||
- | If the subscriber has both IPv6- and PD-prefix, then such subscriber must be marked as multi-bind. The reason is that such subscriber holds //**two**// IPv6-prefixes; | ||
- | |||
- | ==== Enabling IPv6 BRAS/BNG ==== | ||
- | |||
- | IPv6 BRAS/BNG mode is enabled automatically, | ||
- | <code bash> | ||
- | ipv6=1 | ||
- | bras_enable=1 | ||
- | </ | ||
- | |||
- | You can disable IPv6 BRAS by setting in // | ||
- | <code bash> | ||
- | bras_ipv6=0 | ||
- | </ | ||
- | The bras_ipv6 parameter can be turned off ('' | ||
- | |||
- | DHCPv6 request processing mode is enabled since IPv6 BRAS is enabled. You can disable DHCPv6 and ICMPv6 Router Solicitation by setting in // | ||
- | <code bash> | ||
- | bras_dhcp6_mode=0 | ||
- | </ | ||
- | |||
- | Additionally you can set the following parameters in // | ||
- | |||
- | * '' | ||
- | |||
- | * '' | ||
- | |||
- | * [[en: | ||
- | |||
- | * [[en: | ||
- | |||
- | |||
- | ==== Radius-Server Intergation ==== | ||
- | **Example** of an Access-Request for allocating IPv6 prefixes to the subscriber: | ||
- | <code bash> | ||
- | Packet-Type = Access-Request | ||
- | User-Name = " | ||
- | Calling-Station-Id = " | ||
- | Acct-Session-Id = " | ||
- | NAS-Identifier = " | ||
- | NAS-Port-Type = Virtual | ||
- | NAS-Port-Id = " | ||
- | NAS-IP-Address = 188.227.73.40 | ||
- | VasExperts-Service-Type = DHCPv6 | ||
- | VasExperts-DHCPv6-Request = Solicit | ||
- | VasExperts-DHCPv6-Delegated = 1 | ||
- | VasExperts-DHCP-ClientId = 0x00010001237d47fca0b1c2d3006a | ||
- | </ | ||
- | In this example, QinQ is a subscriber' | ||
- | <note warning> | ||
- | **Example** of response: | ||
- | <code bash> | ||
- | Packet-Type = Access-Accept | ||
- | User-Name=" | ||
- | VasExperts-Multi-IP-User = 1 | ||
- | Framed-IPv6-Prefix = 2001: | ||
- | Delegated-IPv6-Prefix = 2001: | ||
- | DNS-Server-IPv6-Address = 2001: | ||
- | DNS-Server-IPv6-Address = 2001: | ||
- | Session-Timeout = 7200 | ||
- | Idle-Timeout = 600 | ||
- | VasExperts-Policing-Profile = " | ||
- | VasExperts-Service-Profile = " | ||
- | VasExperts-Enable-Service = " | ||
- | VasExperts-Enable-Service = " | ||
- | </ | ||
- | In this example, the subscriber recieves two **different** prefixes: | ||
- | * '' | ||
- | * '' | ||
- | |||
- | It is important to note: | ||
- | - for IPv6, the address **always** has to be bound with login. Login is a unique subscriber ID, which can be associated with many IPv4-addresses and IPv6-prefixes. Subscriber' | ||
- | - If the subscriber has several IPv6-prefixes (like in the example given - IPv6-prefix and PD-prefix), then such subscriber must be marked as multi-bind ('' | ||
- | |||
- | '' | ||
- | |||
- | IPv6 prefix leasing time is set by fastdpi.conf-parameters [[en: | ||
- | |||
- | Additional DHCPv6-options can be set with special [[en: | ||
- | |||
- | ==== Setting DHCPv6-options in Radius ==== | ||
- | Stingray SG supports setting practically any DHCPv6 option via special VasExperts VSA attributes. If Stingray SG was installed using standard tools from the official VasExperts repository, then the updated dictionary of all VSA VasExperts is located in the / | ||
- | |||
- | < | ||
- | opt:value | ||
- | </ | ||
- | here: | ||
- | * '' | ||
- | |||
- | ^ VSA attribute | ||
- | | VasExperts-DHCP-Option-IPv6 | Options specifying an IPv6-address or a list of IPv6-addresses | | ||
- | | VasExperts-DHCP-Option-IPv6-Prefix | Options specifying IPv6-prefix | | ||
- | | VasExperts-DHCP6-Option-Num | Specifies an option with a numeric value | | ||
- | | VasExperts-DHCP6-Option-String | Specifies an option with a string value | | ||
- | | VasExperts-DHCP6-Option-Bin | Specifies a binary option as a hex string. Note that when setting a binary option, its value must be in the network byte orderc| | ||
- | |||
- | Example (FreeRadius format): | ||
- | < | ||
- | # Option 22 - list of IPv6 addresses of SIP servers: | ||
- | # Stingray SG will send one option 22 to DHCPv6 with the value - a list of specified IPv6 addresses | ||
- | & | ||
- | & | ||
- | |||
- | # Option 71 - MIPv6 Home Network Prefix Option | ||
- | # sets IPv6-prefix | ||
- | & | ||
- | |||
- | # Option 32 - OPTION_INFORMATION_REFRESH_TIME, | ||
- | & | ||
- | |||
- | # Option 27: NIS-server IPv6-address, | ||
- | & | ||
- | # the same can be set another way: | ||
- | # & | ||
- | |||
- | # Option 43: ERO (Relay Agent Echo Request option) | ||
- | # given as an example of setting an option with a value list of numbers | ||
- | # Stingray SG will combine all attributes of 43 options into one DHCPv6 option with the value ' | ||
- | & | ||
- | & | ||
- | # int16-option in binary form (value 32) | ||
- | & | ||
- | </ | ||
- | |||
- | A complete up-to-date list of all DCHPv6 options and RFC references can be found at the [[https:// | ||
- | |||
- | ==== ICMPv6 settings for fastDPI ==== | ||
- | The following ICMPv6 Router Solicication/ | ||
- | |||
- | ^ Parameter | ||
- | | bras_ipv6_router_pref | number | 0 | BNG mode and priorities as IPv6 router: \\ **-1** - BNG is not an IPv6 router, it does not process ICMPv6 Router Solicitation and does not send Router Advertisement; | ||
- | | bras_icmp6_rtradv_mtu | number | 1500 | The MTU specified in the Router Advertisement. Value 0 - do not add MTU option to Router Advertisement | | ||
- | | bras_icmp6_reachable_time | number | 0 | // | ||
- | | bras_icmp6_hop_limit | number | 64 | // | ||
- | | bras_icmp6_default_lifetime | number | 1800 | // | ||
- | |||
- | |||
- | === Unsolicited RA === | ||
- | Since Stingray SG in L2 BNG mode is an IPv6 router, according to RFC 4861 it periodically announces itself to the local network with ICMPv6 Router Advertisement (unsolicited RA) message. | ||
- | ^ Parameter | ||
- | | bras_icmp6_send_rtradv | number | 0 | Send (1) or not (0) the periodic RA | | ||
- | | bras_icmp6_min_rtradv_interval | number | 200 | Initial boundary of periodic RA sending interval, seconds | | ||
- | | bras_icmp6_max_rtradv_interval | number | 600 | Ending boundary of periodic RA sending interval, seconds | | ||
- | |||
- | When the unsolicited RA sending mode is enabled, the time of the next RA sending is randomly selected from the interval ['' | ||
- | |||
- | |||
- | ==== DHCPv6 settings for fastDPI ==== | ||
- | The following DHCPv6 processing parameters can be set in fastdpi.conf: | ||
- | |||
- | ^ Parameter | ||
- | | bras_dhcp6_enable_rapid_commit | number | 0 | Rapid Commit enabled or disabled\\ The usual procedure for issuing an address in DHCPv6 consists of 4 steps (2 requests + 2 responses). You can use a 2-step procedure (Rapid Commit):\\ **0** - disable Rapid Commit;\\ **1** - enable Rapid Commit. The 2-step procedure for issuing an address will only apply to clients with Rapid Commit support | | ||
- | | bras_dhcp6_enable_unicast | number | 0 | Server Unicast enabled or disabled\\ **0** - unicast disabled. DHCPv6 unicast-requests from the client side will be ignored.\\ **1** - unicast enabled. | | ||
- | | bras_dhcp6_preferred_lifetime | number | 3600 | Preferred IPv6 lease time, seconds. This value must be less than '' | ||
- | | bras_dhcp6_valid_lifetime | number | 7200 | IPv6 lease time, seconds. | ||
- | | bras_dhcp6_preference | number | -1 | The value of the Preference option in the DHCPv6 Advertise. This option sets the preference for a DHCPv6 server in a network with multiple DHCPv6 servers.\\ **-1** - does not specify the Preference option in the DHCPv6 Advertise. | | ||
- | | bras_dhcp6_nak_lifetime | number | 60 | [Stingray SG 8.3] Lifetime of the Radius Reject response, seconds \\ If Radius has not issued an IPv6 address to the client, the client can retry frequent DHCPv6 requests, causing a storm of Access-Request for Radius. With this parameter, you can set the period of time during which the Stingray SG itself will respond to requests from such clients. | | ||