cancel
Showing results for 
Search instead for 
Did you mean: 
cancel
4263
Views
15
Helpful
17
Replies

Configuring ip tcp adjust-mss on ASR-920-12CZ-A

dcrozier7
Level 1
Level 1

I have a need to adjust the tcp mss value to support GRE tunnels on ASR-920-12CZ-A running 16.12.05. I've configured 

ip tcp adjust-mss 

1436 on the egress interface, but I can see in a packet capture that the value is still 1460. I've verified that internet bound traffic does traverse this interface, and I also run this through a CSR1000v in CML and it worked as it should. Are there any device limitations that I'm running into? I'm going crazy trying to get this working. I've looked through many articles and forum posts, and haven't seen anything relevant aside from how the command/function is supposed to work. 

 

Any help would be greatly appreciated. 

1 Accepted Solution

Accepted Solutions

Thanks for all of the input. I finally got confirmation from Cisco TAC and their Business Unit, this feature/command is not supported by the ASR-920 and is not on the roadmap to be implemented. So we will be eventually replacing these with another router at some point, meanwhile we've applied the MSS change to the endpoints which is less than ideal but it works for now. 

View solution in original post

17 Replies 17

ip tcp adjust-mss

is different than

ip mtu

 
for your case you need to config

ip mtu

to be 1436, and

ip tcp mss 

lower than this value at least 40 bytes.

In our case we will have asymmetric routing, where traffic leaving the router doesn't traverse the GRE tunnels, but the return traffic will. This is for a ddos protection service. Their guides and configuration samples are telling me that we need to have mss clamping in place. 

I dont get what you want,

But 

Ip tcp mss

only adjust mss of tcp segemnt not adjust mtu of ip packet that why ypu see 1460 in capture,

I.e. 

Ip tcp mss

1436 + gre and ip header which is in you case 24 bytes=

ip mtu

 

 

If you want to make

ip mtu

1436 then you need 

Ip tcp mss 

1412 

My main issue is why

ip tcp adjust-mss

is not applying to the traffic flowing through it, I am looking at the mss value in the tcp handshake. When I put the same configuration in the virtual lab, I get the results I am looking for. Both are running IOS-XE but different versions, so its not an exact simulation. It looks like I'm either hitting a bug or this is something is not supported by the router, though I'm not finding any documents confirming either.

this comment is edit
OK, in your case are you config

ip tcp mss

with in both side of tunnel ??

the router adjunct the MSS in SYN i.e. the client intiatie tcp traffic must be behind the router config with

ip tcp mss

, if you config in other peer I don't think it will take effect.
so you need to config in both side.

"so you need to config in both side."

That's often done, but I recall (?) TCP

mss-adjust 

will work on ingress or egress traffic on interface it's applied to.

You can adjust a GRE tunnel's IP MTU to 1476, to try to avoid fragmentation for non-TCP traffic.  (For this to work, transmitting client needs to set DF bit.)

TCP

mss-adjust

usually, for GRE, would be set to 1436.

BTW, great Cisco Tech Note on dealing with IPv4 fragmentation, in different situations.  I recall (?) this Tech Note might also address using PMTUD on tunnel's egress traffic (in case, somewhere along the path, a 1500 MTU isn't available.

please see below my comment 
thanks 

Hello
My understanding TCP-MSS  is relevant to the interface mtu, and also relevance is taken on directly connected links so if both endpoints are NOT directly connected and there is additional inpath links with smaller interface mtu then TCP-MSS wont work and fragmentation can be introduced, as such PMTUD would be required to accommodate the inpath links between those end points.


Please rate and mark as an accepted solution if you have found any of the information provided useful.
This then could assist others on these forums to find a valuable answer and broadens the community’s global network.

Kind Regards
Paul

Joseph W. Doherty
Hall of Fame
Hall of Fame

The TCP

adjust-mss 

only works during TCP session setup.  I.e. enabling it won't impact existing TCP sessions.

You mention enabling on "egress interface".  With GRE, you'll want to apply it on the GRE tunnel interface.

 

@Joseph W. Doherty @dcrozier7 
Mr.Joseph point that you apply the MSS in egress interface not under the GRE tunnel interface SO
I do lab and config
1- config the

ip tcp adjust-mss 

(1000) under egress interface "tunnel source"
the result is 
TCP handshake override the value of MSS in egress interface and use default 1460

2-config the

ip tcp adjust-mss

(1000) under GRE tunnel interface 
the result is
TCP handshake set the value of MSS to 1000 <<<<

Now both side vs single side

single Sided 
depend on initiate traffic
if the

tcp adjust-mss 

is config on the side of initiate traffic then 
SYN 1000
SYN ACK 1000
if the

tcp adjust-mss 

is config on the other side then
SYN 1460
SYN ACK 1000

double side 
both side use same MSS in SYN and SYN+ACK
SYN 1000
SYN ACK 1000

"Mr.Joseph point that you apply the MSS in egress interface not under the GRE tunnel interface SO"

Sorry, I must have been unclear.  What I'm trying to say is the converse.  I.e.

mss-adjust

on the tunnel interface, not the physical egress interface (i.e. interface transmitting [or receiving] the GRE encapsulated packets).

As to single side vs. double side, I recall (?) actual MSS used by both sides is the LCD.  I.e. both sides can have different MSSs, but they will both use the lower value.

"See" what happens after session setup when only using "single sided" MSS adjust.

dcrozier7
Level 1
Level 1

Thank you all for the feedback and input, but this still doesn't help our situation. Maybe I was unclear in the original post. Here is what I've gotten from the vendor support.

Reasoning about MSS can feel backwards, especially in scenarios with asymmetric routing. This is very common with Magic Transit, where Internet → your traffic goes through a GRE tunnel and thus has MTU 1476, while you → Internet traffic does not go through GRE and has path MTU 1500. In this scenario, we want to reduce the MSS value in packets from your end → Internet in order reduce the size of packets sent from Internet → you. This means that the configuration must be done either on the your end-hosts, or an MSS clamp must be applied on some intermediary device on the egress path of traffic leaving their network.

 

On my tunnel interfaces, I have both

ip mtu 1476
ip tcp adjust-mss 1436

 

On the physical interface I have

 ip tcp adjust-mss 1436

 

Ingress traffic from the internet goes through the tunnel, while egress traffic out to the internet does not. So I do not need to set the MTU on Egress to 1476 as far as I understand, and what they are telling me. 

 

See the attached screenshot for a better picture of the setup. 

 

Meanwhile I am in the process of purchasing a support contract to have Cisco TAC take a look. I think that its not a problem with the configuration, but maybe a limitation of the hardware or a bug. Its pretty similar to this one, though this is for ASR9000, I have ASR920 https://quickview.cloudapps.cisco.com/quickview/bug/CSCvg25871

Scenario 4 shows an asymmetric routing example where one of the paths has a smaller minimum MTU than the other. Asymmetric routing occurs when different paths are taken to send and receive data between two endpoints. In this scenario, PMTUD will trigger the lowering of the send MSS only in one direction of a TCP flow. The traffic from the TCP client to the server flows through Router A and Router B, whereas the return traffic that comes from the server to the client flows through Router D and Router C. When the TCP server sends packets to the client, PMTUD will trigger the server to lower the send MSS because Router D must fragment the 4092 byte packets before it can send them to Router C.

The client, on the other hand, will never receive an ICMP "Destination Unreachable" message with the code that indicates "fragmentation needed and DF set" because Router A does not have to fragment packets when it sends them to the server through Router B.

 

https://www.cisco.com/c/en/us/support/docs/ip/generic-routing-encapsulation-gre/25885-pmtud-ipfrag.html