You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							72 lines
						
					
					
						
							3.4 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							72 lines
						
					
					
						
							3.4 KiB
						
					
					
				| import org.apache.kafka.clients.admin.AdminClient; | |
| import org.apache.kafka.clients.admin.AdminClientConfig; | |
| import org.apache.kafka.clients.admin.DescribeClusterResult; | |
| import org.apache.kafka.clients.admin.ListTopicsResult; | |
| 
 | |
| import java.util.Properties; | |
| import java.util.concurrent.TimeUnit; | |
| 
 | |
| public class JavaAdminClientTest { | |
|     public static void main(String[] args) { | |
|         // Set uncaught exception handler to catch AdminClient thread errors | |
|         Thread.setDefaultUncaughtExceptionHandler((t, e) -> { | |
|             System.err.println("UNCAUGHT EXCEPTION in thread " + t.getName() + ":"); | |
|             e.printStackTrace(); | |
|         }); | |
| 
 | |
|         String bootstrapServers = args.length > 0 ? args[0] : "localhost:9093"; | |
| 
 | |
|         System.out.println("Testing Kafka wire protocol with broker: " + bootstrapServers); | |
| 
 | |
|         Properties props = new Properties(); | |
|         props.put(AdminClientConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrapServers); | |
|         props.put(AdminClientConfig.REQUEST_TIMEOUT_MS_CONFIG, 10000); | |
|         props.put(AdminClientConfig.DEFAULT_API_TIMEOUT_MS_CONFIG, 10000); | |
|         props.put(AdminClientConfig.CLIENT_ID_CONFIG, "java-admin-test"); | |
|         props.put(AdminClientConfig.CONNECTIONS_MAX_IDLE_MS_CONFIG, 120000); | |
|         props.put(AdminClientConfig.SOCKET_CONNECTION_SETUP_TIMEOUT_MS_CONFIG, 10000); | |
|         props.put(AdminClientConfig.SOCKET_CONNECTION_SETUP_TIMEOUT_MAX_MS_CONFIG, 30000); | |
|         props.put(AdminClientConfig.SECURITY_PROTOCOL_CONFIG, "PLAINTEXT"); | |
|         props.put(AdminClientConfig.RECONNECT_BACKOFF_MS_CONFIG, 50); | |
|         props.put(AdminClientConfig.RECONNECT_BACKOFF_MAX_MS_CONFIG, 1000); | |
| 
 | |
|         System.out.println("Creating AdminClient with config:"); | |
|         props.forEach((k, v) -> System.out.println("  " + k + " = " + v)); | |
| 
 | |
|         try (AdminClient adminClient = AdminClient.create(props)) { | |
|             System.out.println("AdminClient created successfully"); | |
|             Thread.sleep(2000); // Give it time to initialize | |
|  | |
|             // Test 1: Describe Cluster (uses Metadata API internally) | |
|             System.out.println("\n=== Test 1: Describe Cluster ==="); | |
|             try { | |
|                 DescribeClusterResult clusterResult = adminClient.describeCluster(); | |
|                 String clusterId = clusterResult.clusterId().get(10, TimeUnit.SECONDS); | |
|                 int nodeCount = clusterResult.nodes().get(10, TimeUnit.SECONDS).size(); | |
|                 System.out.println("Cluster ID: " + clusterId); | |
|                 System.out.println("Nodes: " + nodeCount); | |
|             } catch (Exception e) { | |
|                 System.err.println("Describe Cluster failed: " + e.getMessage()); | |
|                 e.printStackTrace(); | |
|             } | |
| 
 | |
|             // Test 2: List Topics | |
|             System.out.println("\n=== Test 2: List Topics ==="); | |
|             try { | |
|                 ListTopicsResult topicsResult = adminClient.listTopics(); | |
|                 int topicCount = topicsResult.names().get(10, TimeUnit.SECONDS).size(); | |
|                 System.out.println("Topics: " + topicCount); | |
|             } catch (Exception e) { | |
|                 System.err.println("List Topics failed: " + e.getMessage()); | |
|                 e.printStackTrace(); | |
|             } | |
| 
 | |
|             System.out.println("\nAll tests completed!"); | |
| 
 | |
|         } catch (Exception e) { | |
|             System.err.println("AdminClient creation failed: " + e.getMessage()); | |
|             e.printStackTrace(); | |
|             System.exit(1); | |
|         } | |
|     } | |
| }
 |