以下是使用Angular 7消费未暴露的Kubernetes服务的解决方法,包含代码示例。
首先,确保已经安装了Angular CLI和Node.js。
ng new kubernetes-consumer
cd kubernetes-consumer
ng add @angular/commont/http
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Observable } from 'rxjs';
@Injectable({
providedIn: 'root'
})
export class KubernetesService {
private apiUrl = 'http://:<端口号>';
constructor(private http: HttpClient) { }
getKubernetesData(): Observable {
return this.http.get(`${this.apiUrl}/api/data`);
}
}
请将
和<端口号>
替换为实际的Kubernetes服务的IP地址和端口号。
import { Component, OnInit } from '@angular/core';
import { KubernetesService } from './kubernetes.service';
@Component({
selector: 'app-root',
template: `
Data from Kubernetes API:
- {{ item }}
`
})
export class AppComponent implements OnInit {
kubernetesData: any;
constructor(private kubernetesService: KubernetesService) { }
ngOnInit() {
this.kubernetesService.getKubernetesData().subscribe(data => {
this.kubernetesData = data;
});
}
}
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { HttpClientModule } from '@angular/common/http';
import { AppComponent } from './app.component';
import { KubernetesService } from './kubernetes.service';
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
HttpClientModule
],
providers: [KubernetesService],
bootstrap: [AppComponent]
})
export class AppModule { }
ng serve --open
应用程序将在浏览器中打开,并从Kubernetes服务中获取数据并显示在页面上。
请确保替换代码中的
和<端口号>
为实际的Kubernetes服务的IP地址和端口号。