Programming Kubernetes. Developing Cloud-Native Applications - Helion
ISBN: 978-14-920-4705-6
stron: 272, Format: ebook
Data wydania: 2019-07-18
Księgarnia: Helion
Cena książki: 194,65 zł (poprzednio: 218,71 zł)
Oszczędzasz: 11% (-24,06 zł)
If you’re looking to develop native applications in Kubernetes, this is your guide. Developers and AppOps administrators will learn how to build Kubernetes-native applications that interact directly with the API server to query or update the state of resources. AWS developer advocate Michael Hausenblas and Red Hat principal software engineer Stefan Schimanski explain the characteristics of these apps and show you how to program Kubernetes to build them.
You’ll explore the basic building blocks of Kubernetes, including the client-go API library and custom resources. All you need to get started is a rudimentary understanding of development and system administration tools and practices, such as package management, the Go programming language, and Git.
- Walk through Kubernetes API basics and dive into the server’s inner structure
- Explore Kubernetes’s programming interface in Go, including Kubernetes API objects
- Learn about custom resources—the central extension tools used in the Kubernetes ecosystem
- Use tags to control Kubernetes code generators for custom resources
- Write custom controllers and operators and make them production ready
- Extend the Kubernetes API surface by implementing a custom API server
Osoby które kupowały "Programming Kubernetes. Developing Cloud-Native Applications", wybierały także:
- Windows Media Center. Domowe centrum rozrywki 66,67 zł, (8,00 zł -88%)
- Przywództwo w świecie VUCA. Jak być skutecznym liderem w niepewnym środowisku 58,64 zł, (12,90 zł -78%)
- Mapa Agile & Scrum. Jak si 57,69 zł, (15,00 zł -74%)
- Sztuka podst 53,46 zł, (13,90 zł -74%)
- Lean dla bystrzaków. Wydanie II 49,62 zł, (12,90 zł -74%)
Spis treści
Programming Kubernetes. Developing Cloud-Native Applications eBook -- spis treści
- Preface
- Who Should Read This Book
- Why We Wrote This Book
- Ecosystem
- Technology You Need to Understand
- Conventions Used in This Book
- Using Code Examples
- OReilly Online Learning
- How to Contact Us
- Acknowledgments
- 1. Introduction
- What Does Programming Kubernetes Mean?
- A Motivational Example
- Extension Patterns
- Controllers and Operators
- The Control Loop
- Events
- Edge- Versus Level-Driven Triggers
- Changing Cluster Objects or the External World
- Optimistic Concurrency
- Operators
- Summary
- 2. Kubernetes API Basics
- The API Server
- The HTTP Interface of the API Server
- API Terminology
- Kubernetes API Versioning
- Declarative State Management
- Using the API from the Command Line
- How the API Server Processes Requests
- Summary
- The API Server
- 3. Basics of client-go
- The Repositories
- The Client Library
- Kubernetes API Types
- API Machinery
- Creating and Using a Client
- Versioning and Compatibility
- API Versions and Compatibility Guarantees
- Kubernetes Objects in Go
- TypeMeta
- ObjectMeta
- spec and status
- Client Sets
- Status Subresources: UpdateStatus
- Listings and Deletions
- Watches
- Client Expansion
- Client Options
- Informers and Caching
- Work Queue
- API Machinery in Depth
- Kinds
- Resources
- REST Mapping
- Scheme
- Vendoring
- glide
- dep
- Go Modules
- Summary
- The Repositories
- 4. Using Custom Resources
- Discovery Information
- Type Definitions
- Advanced Features of Custom Resources
- Validating Custom Resources
- Short Names and Categories
- Printer Columns
- Subresources
- Status subresource
- Scale subresource
- A Developers View on Custom Resources
- Dynamic Client
- Typed Clients
- Anatomy of a type
- Golang package structure
- Typed client created via client-gen
- controller-runtime Client of Operator SDK and Kubebuilder
- Summary
- 5. Automating Code Generation
- Why Code Generation
- Calling the Generators
- Controlling the Generators with Tags
- Global Tags
- Local Tags
- deepcopy-gen Tags
- runtime.Object and DeepCopyObject
- client-gen Tags
- informer-gen and lister-gen
- Summary
- 6. Solutions for Writing Operators
- Preparation
- Following sample-controller
- Bootstrapping
- Business Logic
- Kubebuilder
- Bootstrapping
- Business Logic
- The Operator SDK
- Bootstrapping
- Business Logic
- Other Approaches
- Uptake and Future Directions
- Summary
- 7. Shipping Controllers and Operators
- Lifecycle Management and Packaging
- Packaging: The Challenge
- Helm
- Kustomize
- Other Packaging Options
- Packaging Best Practices
- Lifecycle Management
- Production-Ready Deployments
- Getting the Permissions Right
- Automated Builds and Testing
- Custom Controllers and Observability
- Logging
- Monitoring, instrumentation, and auditing
- Summary
- Lifecycle Management and Packaging
- 8. Custom API Servers
- Use Cases for Custom API Servers
- Example: A Pizza Restaurant
- The Architecture: Aggregation
- API Services
- Inner Structure of a Custom API Server
- Delegated Authentication and Trust
- Delegated Authorization
- Writing Custom API Servers
- Options and Config Pattern and Startup Plumbing
- The First Start
- Internal Types and Conversion
- Writing the API Types
- Conversions
- Defaulting
- Roundtrip Testing
- Validation
- Registry and Strategy
- Generic registry
- Strategy
- Wiring a strategy into the generic registry
- API Installation
- Admission
- Implementation
- Registering
- Plumbing resources
- Deploying Custom API Servers
- Deployment Manifests
- Setting Up RBAC
- Running the Custom API Server Insecurely
- Certificates and Trust
- Sharing etcd
- Summary
- 9. Advanced Custom Resources
- Custom Resource Versioning
- Revising the Pizza Restaurant
- Conversion Webhook Architecture
- Conversion Webhook Implementation
- Setting Up the HTTPS Server
- Deploying the Conversion Webhook
- Seeing Conversion in Action
- Admission Webhooks
- Admission Requirements in the Restaurant Example
- Admission Webhook Architecture
- Registering Admission Webhooks
- Implementing an Admission Webhook
- Admission Webhook in Action
- Structural Schemas and the Future of CustomResourceDefinitions
- Structural Schemas
- Pruning Versus Preserving Unknown Fields
- Controlling Pruning
- IntOrString and RawExtensions
- Default Values
- Summary
- Custom Resource Versioning
- A. Resources
- General
- Books
- Tutorials and Examples
- Articles
- Repositories
- Index