-
-
Notifications
You must be signed in to change notification settings - Fork 17
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: route proxy to server internal network through internal DNS (#357)
* feat(shulker-crds): add lifecycle strategy to MinecraftServer CRD * feat(shulker-operator): inject SHULKER_SERVER_LIFECYCLE_STRATEGY env to server * feat(shulker-server-agent): implement lifecycle strategies * docs: add lifecycle strategies recipe * chore: fix some warnings * feat(shulker-operator): create headless service to have all cluster pods inside it * feat(shulker-proxy-agent): use internal DNS through headless service rather than GameServer status
- Loading branch information
1 parent
a8a33ab
commit 5f12300
Showing
13 changed files
with
203 additions
and
41 deletions.
There are no files selected for viewing
105 changes: 105 additions & 0 deletions
105
packages/shulker-operator/src/reconcilers/minecraft_cluster/headless_service.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,105 @@ | ||
use std::collections::BTreeMap; | ||
|
||
use k8s_openapi::api::core::v1::Service; | ||
use k8s_openapi::api::core::v1::ServiceSpec; | ||
use kube::core::ObjectMeta; | ||
use kube::Api; | ||
use kube::Client; | ||
use kube::ResourceExt; | ||
|
||
use shulker_crds::v1alpha1::minecraft_cluster::MinecraftCluster; | ||
use shulker_kube_utils::reconcilers::builder::ResourceBuilder; | ||
|
||
use super::MinecraftClusterReconciler; | ||
|
||
pub struct HeadlessServiceBuilder { | ||
client: Client, | ||
} | ||
|
||
#[async_trait::async_trait] | ||
impl<'a> ResourceBuilder<'a> for HeadlessServiceBuilder { | ||
type OwnerType = MinecraftCluster; | ||
type ResourceType = Service; | ||
type Context = (); | ||
|
||
fn name(cluster: &Self::OwnerType) -> String { | ||
format!("{}-cluster", cluster.name_any()) | ||
} | ||
|
||
fn api(&self, cluster: &Self::OwnerType) -> kube::Api<Self::ResourceType> { | ||
Api::namespaced(self.client.clone(), cluster.namespace().as_ref().unwrap()) | ||
} | ||
|
||
async fn build( | ||
&self, | ||
cluster: &Self::OwnerType, | ||
name: &str, | ||
_existing_service: Option<&Self::ResourceType>, | ||
_context: Option<Self::Context>, | ||
) -> Result<Self::ResourceType, anyhow::Error> { | ||
let service = Service { | ||
metadata: ObjectMeta { | ||
name: Some(name.to_string()), | ||
namespace: Some(cluster.namespace().unwrap().clone()), | ||
labels: Some(MinecraftClusterReconciler::get_labels( | ||
cluster, | ||
"service".to_string(), | ||
"minecraft-server-headless".to_string(), | ||
)), | ||
..ObjectMeta::default() | ||
}, | ||
spec: Some(ServiceSpec { | ||
selector: Some(BTreeMap::from([( | ||
"minecraftcluster.shulkermc.io/name".to_string(), | ||
cluster.name_any(), | ||
)])), | ||
type_: None, | ||
cluster_ip: Some("None".to_string()), | ||
ports: Some(vec![]), | ||
..ServiceSpec::default() | ||
}), | ||
..Service::default() | ||
}; | ||
|
||
Ok(service) | ||
} | ||
} | ||
|
||
impl HeadlessServiceBuilder { | ||
pub fn new(client: Client) -> Self { | ||
HeadlessServiceBuilder { client } | ||
} | ||
} | ||
|
||
#[cfg(test)] | ||
mod tests { | ||
use shulker_kube_utils::reconcilers::builder::ResourceBuilder; | ||
|
||
use crate::reconcilers::minecraft_cluster::fixtures::{create_client_mock, TEST_CLUSTER}; | ||
|
||
#[test] | ||
fn name_contains_cluster_name() { | ||
// W | ||
let name = super::HeadlessServiceBuilder::name(&TEST_CLUSTER); | ||
|
||
// T | ||
assert_eq!(name, "my-cluster-cluster"); | ||
} | ||
|
||
#[tokio::test] | ||
async fn build_snapshot() { | ||
// G | ||
let client = create_client_mock(); | ||
let builder = super::HeadlessServiceBuilder::new(client); | ||
let name = super::HeadlessServiceBuilder::name(&TEST_CLUSTER); | ||
|
||
// W | ||
let service = builder | ||
.build(&TEST_CLUSTER, &name, None, None) | ||
.await | ||
.unwrap(); | ||
|
||
// T | ||
insta::assert_yaml_snapshot!(service); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
22 changes: 22 additions & 0 deletions
22
...er_operator__reconcilers__minecraft_cluster__headless_service__tests__build_snapshot.snap
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
--- | ||
source: packages/shulker-operator/src/reconcilers/minecraft_cluster/headless_service.rs | ||
expression: service | ||
--- | ||
apiVersion: v1 | ||
kind: Service | ||
metadata: | ||
labels: | ||
app.kubernetes.io/component: minecraft-server-headless | ||
app.kubernetes.io/instance: service-my-cluster | ||
app.kubernetes.io/managed-by: shulker-operator | ||
app.kubernetes.io/name: service | ||
app.kubernetes.io/part-of: cluster-my-cluster | ||
minecraftcluster.shulkermc.io/name: my-cluster | ||
name: my-cluster-cluster | ||
namespace: default | ||
spec: | ||
clusterIP: None | ||
ports: [] | ||
selector: | ||
minecraftcluster.shulkermc.io/name: my-cluster | ||
|
27 changes: 27 additions & 0 deletions
27
...ncilers__minecraft_cluster__minecraft_server_headless_service__tests__build_snapshot.snap
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
--- | ||
source: packages/shulker-operator/src/reconcilers/minecraft_cluster/minecraft_server_headless_service.rs | ||
expression: service | ||
--- | ||
apiVersion: v1 | ||
kind: Service | ||
metadata: | ||
labels: | ||
app.kubernetes.io/component: minecraft-server-headless | ||
app.kubernetes.io/instance: service-my-cluster | ||
app.kubernetes.io/managed-by: shulker-operator | ||
app.kubernetes.io/name: service | ||
app.kubernetes.io/part-of: cluster-my-cluster | ||
minecraftcluster.shulkermc.io/name: my-cluster | ||
name: my-cluster-servers | ||
namespace: default | ||
spec: | ||
clusterIP: None | ||
ports: | ||
- name: minecraft | ||
port: 25565 | ||
protocol: TCP | ||
targetPort: minecraft | ||
selector: | ||
app.kubernetes.io/component: minecraft-server | ||
minecraftcluster.shulkermc.io/name: my-cluster | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.