400 likes | 592 Views
Source-Specific Multicast (SSM ) for application developers. Agenda. Review current IP Multicast model, issues, current solution Introduce SSM model, terminology, relationship to IGMPv3 Example of operations Current vs. SSM Review SSM Co-existence, advantages
E N D
Agenda • Review current IP Multicast • model, issues, current solution • Introduce SSM • model, terminology, relationship to IGMPv3 • Example of operations • Current vs. SSM • Review SSM • Co-existence, advantages • How to use SSM in applications • Issues
Internet Standard Multicast (ISM) • ISM service model (RFC1112): • Sources simply send traffic to a host-group G,They do not know who the receivers are.sendto(sock, packet, …, G,…) • Receiversjoin a host-group Gsetsockopt(sock,…, IP_ADD_MEMBERSHIP,(G, iface), …) • Receive traffic from all sources sending to G.Recvfrom(sock, &packet, … &source, …) • Receivers not need to know who the sources are.(but may learn once they receive the packets of course).
ISM, IGMPv3 and SSM • ISM: Powerful, proven model • Self-configuring, resilient distributed applications • Resource discovery mechanisms • Very easy for applications • What is New ? • IGMPv3: model extension, source filtering, enables SSM. • SSM solves ISM issues for Internet Broadcast apps. • SSM extends IP Multicast, does not replace ISM.
Issues with ISM • Address allocation and management • One application per group address • Denial of Service Attacks • How to avoid unwanted sources traffic ? • Easy of scalability of service provisioning • Shared-Tree - Interdomain complexity (BGMP,..), no gain for few-sources apps. • Source-Tree - Source discovery management complexity
Exploiting existing solutions • Internet standard Multicast solution: PIM-SM + MSDP • Source discovery with RPs and MSDP • Receiver initiated source-trees • SSM: Move resource discovery into applications: • Without the issues from the previous slide • Utilising existing PIM-SM/MSDP deployments • Co-existing with the ISM and it’s applications.
Source Specific MulticastService Model • Sources simply send traffic to a host-group G,No change over Internet Standard Multicast service. sendto(sock, packet, …, G,…) • Receiverssubscribe to (S,G) channel(s) setsockopt(sock,…, IP_ADD_SOURCE_MEMBERSHIP, (S, G, iface), …) • Receive traffic from “channel” S sending to G. recvfrom(sock, &packet, … &source, …) • Receiver need to know the sources before receiving!
SSM and IGMPv3 • IGMPv3 • INCLUDE{sourcelist, G} • receive traffic for G only from sources in sourcelist. • EXCLUDE{sourcelist, G} • receive traffic for G except from sources in sourcelist • SSM: • Only INCLUDE type memberships supported. IGMPv1, IGMPv2 and IGMPv3 EXCLUDE memberships are ignored in SSM by routers. • Traffic from unknown sources not forwarded
SSM versus ISM • SSM does not support unmodified Applications! No way to request reception of traffic from unknown sourcesExisting receiver applications will not work with SSM ! • New terminology: A group G alone has no meaning of it’s own in SSM. It is like the trailing digits in a telephone number ! Service Model: RFC1112 Source-SpecificNetwork Abstraction: group channelIdentifier: G S,GReceiver Operations: join, leave subscribe, unsubscribe
ISM traffic delivery example S1Send to G S2Send to G RP
ISM traffic delivery example S1Send to G S2Send to G register register First-hop routerssend register messagesto the RP RP
ISM traffic delivery example S1Send to G S2Send to G registerstop register stop RP has no receiversjoined, so it sendsback register-stopmessages, butremembers thatthe sources areactive RP (S1,G)(S2,G)
ISM traffic delivery example R3Join to G R1Join to G R2Join to G S1Send to G S2Send to G RP (S1,G)(S2,G) Receivers startto join to the group
ISM traffic delivery example R3Join to G R1Join to G R2Join to G S1Send to G S2Send to G And the last-hopDRs will thensend (*,G)PIM-JOIN packets towards the RP RP (S1,G)(S2,G) (*,G) Join (*,G) Join (*,G) (*,G)
ISM traffic delivery example R3Join to G R1Join to G R2Join to G S1Send to G S2Send to G This will establishtraffic deliveryfrom the RPtowards the receivers on the RPT, exceptthat there is no traffic yet RP (S1,G)(S2,G) (*,G) (*,G)
ISM traffic delivery example R3Join to G R1Join to G R2Join to G S1Send to G S2Send to G (S1,G) Join (S2,G) Join But the RP knows about two sources for G and thus sends (Si,G)PIM-JOINS to themto receive their traffic. RP (S1,G)(S2,G) (*,G) (*,G)
ISM traffic delivery example R3Join to G R1Join to G R2Join to G S1Send to G S2Send to G The RP willreceive the trafficfrom sources S1 andS2 on the shortestpath RP (S1,G)(S2,G) (*,G) (*,G)
ISM traffic delivery example R3Join to G R1Join to G R2Join to G S1Send to G S2Send to G And sends it downon the RPT towardsthe receivers RP (S1,G)(S2,G) (*,G) (*,G)
ISM traffic delivery example R3Join to G R1Join to G R2Join to G S1Send to G S2Send to G Once the last-hoprouters receive traffic from new sources, they will join to the SPT for these sources(shown only forS1 from one router) (S1,G) Join RP (S1,G) Join (S1,G),(S2,G) (S1,G),(S2,G)
ISM traffic delivery example R3Join to G R1Join to G R2Join to G S1Send to G S2Send to G Because the inputinterface is different in this case, the router sends up (S1,G,Rpbit) Prune, once traffic arrives on the SPT RP (S1,G,RPbit) Prune (S1,G),(S2,G) (S1,G),(S2,G)
ISM traffic delivery example R3Join to G R1Join to G R2Join to G S1Send to G S2Send to G And finally, traffic forwarding is on the SPTs RP (S1,G),(S2,G) (S1,G),(S2,G)
ISM traffic delivery example S1Send to G S2Send to G If S1/R1 and S2/R3were independentapplications, their traffic would disturbeach other RP R3Join to G R1Join to G R2Join to G
SSM traffic delivery example Now we reuse Gfor two independentapplications withSSM
SSM traffic delivery example S1Send to G S2Send to G Sources send to SSM group G, no registering happens there
SSM traffic delivery example S1Send to G S2Send to G Incompatible receiver joins, last-hop router has to ignore the request as there is no RP in SSM! R2Join to G
SSM traffic delivery example S1Send to G S2Send to G SSM-enabled receivers subscribe to channels on the same group but for different sources R3Subscribe(S2,G) channel R1Subscribe(S1,G) channel R2Join to G
SSM traffic delivery example S1Send to G S2Send to G (S2,G) Join Now we reuse Gfor two independentapplications withSSM (S1,G) Join (S1,G) Join (S2,G) Join R3Subscribe(S2,G) channel R1Subscribe(S1,G) channel R2Join to G
SSM traffic delivery example S1Send to G S2Send to G And traffic flows down the shortest-paths, but legacy receivers will not get their traffic. R3Subscribe(S2,G) R1Subscribe(S1,G) R2Join to G
SSM and ISM co-existence • SSM used only in “SSM-Range”: • 232.0.0.0 … 232.255.255.255 (Globally assigned by IANA) • Existing application may not use SSM-Range. • Global use of SSM-Range needed toguarantee conflict free address-reuse
Advantages of SSM • No address management in SSM-Range • All (Si,G) channels indendent of each other. • ~2^24 channels / source. • Group address has only host-local significance. • No traffic from unwanted sources Network benefits: • Easily deployed • Support only needed in last-hop router. • Rest of the network may use PIM-SM (+access config). • Simpler management than ISM
Applications for SSM • Attractive for Internet-wide broadcast-style applications: • Well known sources, very static • Primary targets for DoS attacks • Current problems with address availability • Impossible for SSM: • Resource discovery style applications • Not useful with SSM: • Everything that should use “shared-tree” forwarding (Many Sources, frequently changing sources) • Others: • How difficult is source-discovery for an application ? • How useful is it to do it for the benefits of SSM ?
Traffic delivery exampleISM + IGMPv3 (1) R3INCLUDE({S2},G) R1INCLUDE({S1},G) R2EXCLUDE ({}, G} S1Send to G S2Send to G Wishful thinking ?No, this is possible, but more complex in thenetwork than SSM, also ... RP
Traffic delivery exampleISM + IGMPv3 (2) R3INCLUDE({S2},G) R1INCLUDE({S1},G) R2EXCLUDE ({}, G} S1Send to G S2Send to G …closer to reality.No guarantee thatindependent applications traffic will always stay separate if not usingSSM RP
How to support ISM + SSM (1) • Typical broadcast receiver application get address information from SDP style session information system. • Add support for source addresses. • Use IGMPv3 API. • If session info contains source address(es): • Use IGMPv3 INCLUDE membership API call(s). • Will work with ISM and SSM. • If session is does not contain source addresses: • Use simple group-join (I.e.: IGMPv3 EXCLUDE({},G) ). • Must use addresses not within the SSM-range.
How to support SSM + ISM (2) • Self sustained applications (no session information): • Need to implement “source discovery” to support SSM: • Web-based applications could rely on a Webserver based servlet as an application-RP. • Applications that use INCLUDE style memberships will always work outside of the SSM-Range. • May receive complete group traffic though ! • Need address management outside SSM-range !
Deployment issues • To use SSM, IGMPv3 must be supported in: • The last-hop router • The receiver host OS • The application • Availability ? • Bootstrap solutions (from Cisco): • IGMP v3lite: User-level IGMPv3 API (SSM-subset) (Windows *, …). • URD: Make existing applications SSM-capable through appropriate web-based control. No changes on the receiver host required. • Not meant as a replacement to IGMPv3, but as SSM enablers. • Useful until user deploys full IGMPv3 (/Applications).
References • draft-holbrook-ssm-00.txt - SSM model • draft-bhaskar-pim-ss-00.txt - PIM-SM mods. for PIM-SS • draft-ietf-idmr-igmp-v3-04.txt - IGMPv3 • draft-ietf-idmr-msf-api-00.txt - IGMPv3 API • draft-ietf-pim-v2-sm-01.txt - PIM-SM • draft-shepherd-ssm232-00.txt - Using PIM-SM with SSM-Range • ftp://ftpeng.cisco.com/ipmulticast.htmlfor further information on SSM