Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add The Ability to Quit a Running Server #26

Closed
wants to merge 1 commit into from

Conversation

zicklag
Copy link

@zicklag zicklag commented Nov 14, 2019

Added a running: Arc<AtomicBool> parameter to varlink::listen that, when set to false, will shutdown the server.

Addresses #25.

I'm open to any thoughts. This would be the second breaking API change in 48 hours. ;) Maybe it should be a different function so that we can keep the original listen() function unchanged?

Edit: Also the change needs documentation, but I'll wait until we figure out for sure how we want it before I add that.

Added a `running: Arc<AtomicBool>` parameter to `varlink::listen` that,
when set to false, will shutdown the server.
haraldh added a commit to haraldh/varlink-rust that referenced this pull request Nov 15, 2019
Factor out the `varlink::listen` parameters into a `varlink::ListenConfig` struct,
so we can use ..Default::default().

Add an `stop_listening: Option<Arc<AtomicBool>>` to the `varlink::ListenConfig` struct,
which can be set remotely to break the `varlink::listen` loop.

Stop the running server after 10 seconds

```rust
      use std::{thread, time};
      use std::sync::atomic::Ordering;
      let stop_listening = Arc::new(std::sync::atomic::AtomicBool::new(false));

      let child = {
          let stop_running = stop_listening.clone();
          thread::spawn(move || {
              thread::sleep(time::Duration::from_secs(10));
              // Stop the running server after 10 seconds
              stop_listening.store(true, Ordering::Relaxed);
          })
      };

      varlink::listen(
          service,
          &address,
          &varlink::ListenConfig {
              idle_timeout: timeout,
              stop_listening: Some(stop_listening),
              ..Default::default()
          },
      )?;

      child.join().expect("Error joining thread");
```

Obsoletes varlink#26
Addresses varlink#25
@haraldh
Copy link
Collaborator

haraldh commented Nov 15, 2019

What do you think about PR #27 ??

haraldh added a commit to haraldh/varlink-rust that referenced this pull request Nov 18, 2019
Factor out the `varlink::listen` parameters into a `varlink::ListenConfig` struct,
so we can use ..Default::default().

Add an `stop_listening: Option<Arc<AtomicBool>>` to the `varlink::ListenConfig` struct,
which can be set remotely to break the `varlink::listen` loop.

Stop the running server after 10 seconds

```rust
      use std::{thread, time};
      use std::sync::atomic::Ordering;
      let stop_listening = Arc::new(std::sync::atomic::AtomicBool::new(false));

      let child = {
          let stop_running = stop_listening.clone();
          thread::spawn(move || {
              thread::sleep(time::Duration::from_secs(10));
              // Stop the running server after 10 seconds
              stop_listening.store(true, Ordering::Relaxed);
          })
      };

      varlink::listen(
          service,
          &address,
          &varlink::ListenConfig {
              idle_timeout: timeout,
              stop_listening: Some(stop_listening),
              ..Default::default()
          },
      )?;

      child.join().expect("Error joining thread");
```

Obsoletes varlink#26
Addresses varlink#25
haraldh added a commit to haraldh/varlink-rust that referenced this pull request Nov 18, 2019
Factor out the `varlink::listen` parameters into a `varlink::ListenConfig` struct,
so we can use ..Default::default().

Add an `stop_listening: Option<Arc<AtomicBool>>` to the `varlink::ListenConfig` struct,
which can be set remotely to break the `varlink::listen` loop.

Stop the running server after 10 seconds

```rust
      use std::{thread, time};
      use std::sync::atomic::Ordering;
      let stop_listening = Arc::new(std::sync::atomic::AtomicBool::new(false));

      let child = {
          let stop_running = stop_listening.clone();
          thread::spawn(move || {
              thread::sleep(time::Duration::from_secs(10));
              // Stop the running server after 10 seconds
              stop_listening.store(true, Ordering::Relaxed);
          })
      };

      varlink::listen(
          service,
          &address,
          &varlink::ListenConfig {
              idle_timeout: timeout,
              stop_listening: Some(stop_listening),
              ..Default::default()
          },
      )?;

      child.join().expect("Error joining thread");
```

Obsoletes varlink#26
Addresses varlink#25
haraldh added a commit to haraldh/varlink-rust that referenced this pull request Nov 18, 2019
Factor out the `varlink::listen` parameters into a `varlink::ListenConfig` struct,
so we can use ..Default::default().

Add an `stop_listening: Option<Arc<AtomicBool>>` to the `varlink::ListenConfig` struct,
which can be set remotely to break the `varlink::listen` loop.

Stop the running server after 10 seconds

```rust
      use std::{thread, time};
      use std::sync::atomic::Ordering;
      let stop_listening = Arc::new(std::sync::atomic::AtomicBool::new(false));

      let child = {
          let stop_running = stop_listening.clone();
          thread::spawn(move || {
              thread::sleep(time::Duration::from_secs(10));
              // Stop the running server after 10 seconds
              stop_listening.store(true, Ordering::Relaxed);
          })
      };

      varlink::listen(
          service,
          &address,
          &varlink::ListenConfig {
              idle_timeout: timeout,
              stop_listening: Some(stop_listening),
              ..Default::default()
          },
      )?;

      child.join().expect("Error joining thread");
```

Obsoletes varlink#26
Addresses varlink#25
haraldh added a commit that referenced this pull request Nov 18, 2019
Factor out the `varlink::listen` parameters into a `varlink::ListenConfig` struct,
so we can use ..Default::default().

Add an `stop_listening: Option<Arc<AtomicBool>>` to the `varlink::ListenConfig` struct,
which can be set remotely to break the `varlink::listen` loop.

Stop the running server after 10 seconds

```rust
      use std::{thread, time};
      use std::sync::atomic::Ordering;
      let stop_listening = Arc::new(std::sync::atomic::AtomicBool::new(false));

      let child = {
          let stop_running = stop_listening.clone();
          thread::spawn(move || {
              thread::sleep(time::Duration::from_secs(10));
              // Stop the running server after 10 seconds
              stop_listening.store(true, Ordering::Relaxed);
          })
      };

      varlink::listen(
          service,
          &address,
          &varlink::ListenConfig {
              idle_timeout: timeout,
              stop_listening: Some(stop_listening),
              ..Default::default()
          },
      )?;

      child.join().expect("Error joining thread");
```

Obsoletes #26
Addresses #25
@haraldh haraldh closed this Jan 9, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants