1# AndroidChannelBuilder 2 3Since gRPC's 1.12 release, the `grpc-android` package provides access to the 4`AndroidChannelBuilder` class. Given an Android Context, this builder will 5register a network event listener upon channel construction. The listener is 6used to automatically respond to changes in the device's network state, avoiding 7delays and interrupted RPCs that may otherwise occur. 8 9By default, gRPC uses exponential backoff to recover from connection failures. 10Depending on the scheduled backoff delay when the device regains connectivity, 11this could result in a one minute or longer delay before gRPC re-establishes 12the connection. This delay is removed when `AndroidChannelBuilder` is provided 13with the app's Android Context. Notifications from the network listener will 14cause the channel to immediately reconnect upon network recovery. 15 16On Android API levels 24+, `AndroidChannelBuilder`'s network listener mechanism 17allows graceful switching from cellular to wifi connections. When an Android 18device on a cellular network connects to a wifi network, there is a brief 19(typically 30 second) interval when both cellular and wifi networks remain 20available, then any connections on the cellular network are terminated. By 21listening for changes in the device's default network, `AndroidChannelBuilder` 22sends new RPCs via wifi rather than using an already-established cellular 23connection. Without listening for pending network changes, new RPCs sent on an 24already established cellular connection would fail when the device terminates 25cellular connections. 26 27***Note:*** *Currently, `AndroidChannelBuilder` is only compatible with gRPC 28OkHttp. We plan to offer additional Android-specific features compatible with 29both the OkHttp and Cronet transports in the future, but the network listener 30mechanism is only necessary with OkHttp; the Cronet library internally handles 31connection management on Android devices.* 32 33## Example usage: 34 35In your `build.gradle` file, include a dependency on both `grpc-android` and 36`grpc-okhttp`: 37 38``` 39compile 'io.grpc:grpc-android:1.16.1' // CURRENT_GRPC_VERSION 40compile 'io.grpc:grpc-okhttp:1.16.1' // CURRENT_GRPC_VERSION 41``` 42 43You will also need permission to access the device's network state in your 44`AndroidManifest.xml`: 45 46``` 47<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 48``` 49 50When constructing your channel, use `AndroidChannelBuilder` and provide it with 51your app's Context: 52 53``` 54import io.grpc.android.AndroidChannelBuilder; 55... 56ManagedChannel channel = AndroidChannelBuilder.forAddress("localhost", 8080) 57 .context(getApplicationContext()) 58 .build(); 59``` 60 61You continue to use the constructed channel exactly as you would any other 62channel. gRPC will now monitor and respond to the device's network state 63automatically. When you shutdown the managed channel, the network listener 64registered by `AndroidChannelBuilder` will be unregistered. 65 66