Skip to content

/AWS1/CL_EC2=>MODIFYROUTESERVER()

About ModifyRouteServer

Modifies the configuration of an existing route server.

Amazon VPC Route Server simplifies routing for traffic between workloads that are deployed within a VPC and its internet gateways. With this feature, VPC Route Server dynamically updates VPC and internet gateway route tables with your preferred IPv4 or IPv6 routes to achieve routing fault tolerance for those workloads. This enables you to automatically reroute traffic within a VPC, which increases the manageability of VPC routing and interoperability with third-party workloads.

Route server supports the follow route table types:

  • VPC route tables not associated with subnets

  • Subnet route tables

  • Internet gateway route tables

Route server does not support route tables associated with virtual private gateways. To propagate routes into a transit gateway route table, use Transit Gateway Connect.

For more information see Dynamic routing in your VPC with VPC Route Server in the Amazon VPC User Guide.

Method Signature

IMPORTING

Required arguments:

iv_routeserverid TYPE /AWS1/EC2ROUTESERVERID /AWS1/EC2ROUTESERVERID

The ID of the route server to modify.

Optional arguments:

iv_persistroutes TYPE /AWS1/EC2ROUTESERVERPERSISTR00 /AWS1/EC2ROUTESERVERPERSISTR00

Specifies whether to persist routes after all BGP sessions are terminated.

  • enable: Routes will be persisted in FIB and RIB after all BGP sessions are terminated.

  • disable: Routes will not be persisted in FIB and RIB after all BGP sessions are terminated.

  • reset: If a route server has persisted routes due to all BGP sessions having ended, reset will withdraw all routes and reset route server to an empty FIB and RIB.

iv_persistroutesduration TYPE /AWS1/EC2BOXEDLONG /AWS1/EC2BOXEDLONG

The number of minutes a route server will wait after BGP is re-established to unpersist the routes in the FIB and RIB. Value must be in the range of 1-5. Required if PersistRoutes is enabled.

If you set the duration to 1 minute, then when your network appliance re-establishes BGP with route server, it has 1 minute to relearn it's adjacent network and advertise those routes to route server before route server resumes normal functionality. In most cases, 1 minute is probably sufficient. If, however, you have concerns that your BGP network may not be capable of fully re-establishing and re-learning everything in 1 minute, you can increase the duration up to 5 minutes.

iv_snsnotificationsenabled TYPE /AWS1/EC2BOOLEAN /AWS1/EC2BOOLEAN

Specifies whether to enable SNS notifications for route server events. Enabling SNS notifications persists BGP status changes to an SNS topic provisioned by Amazon Web Services.

iv_dryrun TYPE /AWS1/EC2BOOLEAN /AWS1/EC2BOOLEAN

A check for whether you have the required permissions for the action without actually making the request and provides an error response. If you have the required permissions, the error response is DryRunOperation. Otherwise, it is UnauthorizedOperation.

RETURNING

oo_output TYPE REF TO /aws1/cl_ec2modrouteserverrs /AWS1/CL_EC2MODROUTESERVERRS

Domain /AWS1/RT_ACCOUNT_ID
Primitive Type NUMC

Examples

Syntax Example

This is an example of the syntax for calling the method. It includes every possible argument and initializes every possible value. The data provided is not necessarily semantically accurate (for example the value "string" may be provided for something that is intended to be an instance ID, or in some cases two arguments may be mutually exclusive). The syntax shows the ABAP syntax for creating the various data structures.

DATA(lo_result) = lo_client->/aws1/if_ec2~modifyrouteserver(
  iv_dryrun = ABAP_TRUE
  iv_persistroutes = |string|
  iv_persistroutesduration = 123
  iv_routeserverid = |string|
  iv_snsnotificationsenabled = ABAP_TRUE
).

This is an example of reading all possible response values

lo_result = lo_result.
IF lo_result IS NOT INITIAL.
  lo_routeserver = lo_result->get_routeserver( ).
  IF lo_routeserver IS NOT INITIAL.
    lv_routeserverid = lo_routeserver->get_routeserverid( ).
    lv_long = lo_routeserver->get_amazonsideasn( ).
    lv_routeserverstate = lo_routeserver->get_state( ).
    LOOP AT lo_routeserver->get_tags( ) into lo_row.
      lo_row_1 = lo_row.
      IF lo_row_1 IS NOT INITIAL.
        lv_string = lo_row_1->get_key( ).
        lv_string = lo_row_1->get_value( ).
      ENDIF.
    ENDLOOP.
    lv_routeserverpersistroute = lo_routeserver->get_persistroutesstate( ).
    lv_boxedlong = lo_routeserver->get_persistroutesduration( ).
    lv_boolean = lo_routeserver->get_snsnotificationsenabled( ).
    lv_string = lo_routeserver->get_snstopicarn( ).
  ENDIF.
ENDIF.