61
Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect

Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

  • Upload
    others

  • View
    16

  • Download
    0

Embed Size (px)

Citation preview

Page 1: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

Cloud native and microservices architecture

1

Andrzej KowalczykSenior Solutions Architect

Page 2: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

THE CHANGING WORLD OF APPLICATIONS

Page 3: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

3

“ By 2027, more than 75% of the S&P 500

will be companies that we have not heard of yet. ”

Professor Richard Foster, Yale University

Image source: https://www.flickr.com/photos/onurturkcu/4826048220/

Page 4: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

4

INNOVATION PREVAILS

Source: Yahoo Finance (*Peak Market Value 2006)

Page 5: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security
Page 6: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

MICROSERVICES ARCHITECTURE

Runtime

Service

Runtime

Service

Runtime

Service

Runtime

Service

Runtime

Service

Runtime

Service

Runtime

Service

Application Server

HTML Javascript Web

ServiceServiceService

Service Service Service

Data Access

Runtime

Service

Runtime

Service

Page 7: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

MICROSERVICES ARCHITECTURE

Runtime

Service

Runtime

Service

Runtime

Service

Runtime

Service

Runtime

Service

Runtime

Service

Runtime

Service

Application Server

HTML Javascript Web

ServiceServiceService

Service Service Service

Data Access

DISTRIBUTED

Runtime

Service

Runtime

Service

Page 8: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

DISTRIBUTED ARCHITECTURE

Service ServiceService

Service ServiceService

Service ServiceService

Page 9: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

1. The network is reliable2. Latency is zero3. Bandwidth is infinite4. The network is secure5. Topology doesn't change6. There is one administrator7. Transport cost is zero8. The network is homogeneous

EIGHT FALLACIES OF DISTRIBUTED COMPUTING

Source: https://en.wikipedia.org/wiki/Fallacies_of_distributed_computingPhoto: Icon made by Freepik from www.flaticon.com

Page 11: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

DEPLOYMENT

ServiceContainer

INFRASTRUCTURE

ServiceContainer

ServiceContainer

Page 12: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

Virtual

Cloud

Physical

source code

binarypackage

containerimage

BUILD ONCE, DEPLOY ANYWHERE

Page 13: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

CONFIGURATION

Spring CloudConfig Server

Service

Config

Service

Config

Service

Config

INFRASTRUCTURE

Page 14: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

SERVICE DISCOVERY

Service

Spring CloudConfig Server Netflix Eureka

Netflix Ribbon Config

Service

Config

Service

Config

Svc Discovery Svc Discovery Svc Discovery

INFRASTRUCTURE

Page 15: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

DYNAMIC ROUTING

Spring CloudConfig Server

Service

Netflix EurekaNetflix Ribbon Config

Service

Config

Service

Config

Svc Discovery Svc Discovery Svc Discovery

Routing Routing Routing

Netflix ZuulServer

INFRASTRUCTURE

Page 16: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

DYNAMIC ROUTING

Spring CloudConfig Server

Service

Netflix EurekaNetflix Ribbon Config

Service

Config

Service

Config

Svc Discovery Svc Discovery Svc Discovery

Routing Routing Routing

Netflix ZuulServer

INFRASTRUCTURE

Page 17: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

TRACING AND VISIBILITY

Spring CloudConfig Server

Service

Netflix EurekaNetflix Ribbon Config

Service

Config

Service

Config

Svc Discovery Svc Discovery Svc Discovery

Routing Routing Routing

Netflix ZuulServer

Circuit Breaker Circuit Breaker Circuit Breaker

Tracing Tracing TracingZipKin Server

INFRASTRUCTURE

Page 18: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

WHAT ABOUT…?

POLYGLOT APPS

EXISTING APPS

Page 19: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

THERE SHOULD BE A BETTER WAY

Page 20: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

ADDRESS THE COMPLEXITY IN THE INFRASTRUCTURE

Page 21: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

SERVICECONTAINER

POD

SERVICECONTAINER

POD

SERVICECONTAINER

KUBERNETES

AUTOMATING CONTAINER DEPLOYMENT

INFRASTRUCTURE

Page 22: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

BUILD AND DEPLOY CLOUD-NATIVE APPS WITH RED HAT OPENSHIFT

Service

CONTAINER

Service

CONTAINER

Service

CONTAINER

ANYINFRASTRUCTURE

OpenShift Container Platform(Enterprise Kubernetes)

Amazon Web Services Microsoft Azure Google CloudOpenStackDatacenterLaptop

ANYAPPLICATION

Service

CONTAINER

Service

CONTAINER

Service Discovery

Config Mgmt

Build Automation

Deploy Automation

Monitoring

Log Mgmt

Security

CI/CD Pipelines

Page 23: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

Self-Service

Multi-language

Automation

Collaboration

Seamless

Standards-based

Web-scale

Open Source

Enterprise Grade

Secure

CRITICAL FEATURES FOR BOTH DEV AND OPS

23

Page 24: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

RED HAT OPENSHIFT CONTAINER PLATFORMTransform development and operations

Deploy & manage container b/ apps

Seamless across hybrid clouds

Automated and scalable

Shift to a containerized, DevOps deployment model

Consistency across environments

Key microservices enabler

Page 25: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

25

PRIVATE CLOUD

IMPLEMENT HYBRID INTEGRATION PLATFORM Single platform and toolchain across cloud environments provides consistency and flexibility for current and future deployments

Deploy on-premisePUBLIC CLOUD

Deploy on public cloud providerMANAGED CLOUD

Deployed and managed by Red Hat

Page 26: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

26

NATIVE SUPPORT FOR YOUR PIPELINE

Continuous integration &

testing

Continuous delivery &

deployment

Continuous operations

Build

Test

Release Operate

Deploy Monitor

Continuous assessment

Continuous assessment

Page 27: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

SERVICE MESHA dedicated network for

service-to-service communications

Photo on Visual Hunt

Page 28: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

MICROSERVICES EVOLUTION

Service

Config

Svc Discovery

Routing

Circuit Breaker

Tracing

Service

Platform Container Platform (+ Service Mesh)

...2014 2018

Page 29: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

ENVOY

SERVICE

POD

ENVOY

SERVICE

POD

ENVOY

SERVICE

Pilot Mixer Auth

SERVICE MESH ARCHITECTURE

Applies security, route rules, policies and reports traffic telemetry at the pod level

Jaeger

Page 30: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

FAULT TOLERANCE

Page 31: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

SERVICEA

SERVICEB

CIRCUIT BREAKERS WITHOUT ISTIO

SERVICECCB CB

coupled to the service code

Page 32: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

SERVICEA

ENVOY

POD

SERVICEB

ENVOY

POD

SERVICEC

ENVOY

CIRCUIT BREAKERS WITH ISTIO

transparent to the services

Page 33: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

SERVICEA

ENVOY

POD

SERVICEB

ENVOY

POD

SERVICEC

ENVOY

CIRCUIT BREAKERS WITH ISTIO

improved response time with global circuit status

Page 34: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

SERVICEA

ENVOY

POD

SERVICEB

ENVOY

POD

SERVICEC

ENVOY

TIMEOUTS AND RETRIES WITH ISTIO

configure timeouts and retries, transparent to the services

timeout: 10 secretry: 5

timeout: 15 secretry: 5

Page 35: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

SERVICEA

ENVOY

POD

SERVICEB

ENVOY

POD

SERVICEC

ENVOY

RATE LIMITING WITH ISTIO

limit invocation rates, transparent to the services

max 500 concurrent reqs

max 100 connections

Page 36: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

SERVICE SECURITY

Page 37: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

SERVICEA

SERVICEB

SECURE COMMUNICATION WITHOUT ISTIO

SERVICECTLS TLS TLS TLS

coupled to the service code

Page 38: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

SECURE COMMUNICATION WITH ISTIO

POD

SERVICEA

ENVOY

POD

SERVICEB

ENVOY

POD

SERVICEC

ENVOY

mutual TLS authentication, transparent to the services

TLS TLS

Page 39: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

SERVICEA

ENVOY

POD

SERVICEB

ENVOY

POD

SERVICEC

ENVOY

CONTROL SERVICE ACCESS WITH ISTIO

control the service access flow, transparent to the services

Page 40: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

CHAOS ENGINEERING

Page 41: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

CHAOS ENGINEERING WITHOUT ISTIO

SERVICEA

SERVICEB

SERVICEC

Netflix Chaos Monkeys

Netflix Spinnaker

randomtermination

Page 42: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

SERVICEA

ENVOY

POD

SERVICEB

ENVOY

POD

SERVICEC

ENVOY

CHAOS ENGINEERING WITH ISTIO

inject delays, transparent to the services

10 sec delay in 10% of requests

Page 43: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

inject protocol-specific errors, transparent to the services

POD

SERVICEA

ENVOY

POD

SERVICEB

ENVOY

POD

SERVICEC

ENVOY

CHAOS ENGINEERING WITH ISTIO

HTTP 400in 5% of requests

Page 44: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

DYNAMIC ROUTING

Page 45: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

GatewayServiceSERVICE

A

SERVICEB:1

DYNAMIC ROUTING WITHOUT ISTIO

SERVICEB:2

Netflix ZuulServer

custom code to enable dynamic routing

Page 46: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

SERVICEA

ENVOY

POD

SERVICEB:v2

ENVOY

CANARY DEPLOYMENT WITH ISTIO

POD

SERVICEB:v1

ENVOY

boston employee

everyone

Page 47: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

SERVICEA

ENVOY

POD

SERVICEB:v2

ENVOY

A/B DEPLOYMENT WITH ISTIO

POD

SERVICEB:v1

ENVOY

50% traffic

50% traffic

Page 48: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

SERVICEA

ENVOY

POD

SERVICEB:v2

ENVOY

DARK LAUNCHES WITH ISTIO

POD

SERVICEB:v1

ENVOY

100% traffic

mirror traffic

Page 49: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

DISTRIBUTED TRACING

Page 50: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

SERVICEA

SERVICEB

SERVICEC

DISTRIBUTED TRACING WITHOUT ISTIO

Spring SleuthZipKin

Spring SleuthZipKin

Spring SleuthZipKin

code to enable dynamic tracing

Page 51: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

POD

SERVICEA

ENVOY

POD

SERVICEB

ENVOY

POD

SERVICEC

ENVOY

DISTRIBUTED TRACING WITH ISTIO & JAEGER

discovers service relationships and process times, transparent to the services

SERVICE A SERVICE B SERVICE C210 ms 720 ms

930 ms

Page 52: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

DISTRIBUTED SERVICES PLATFORM

ANYINFRASTRUCTURE

OpenShift Container Platform(Enterprise Kubernetes)

Amazon Web Services Microsoft Azure Google CloudOpenStackDatacenterLaptop

OpenShift Service Mesh(Istio + Jaeger)

ANYAPPLICATION

Service

CONTAINER

Service

CONTAINER

Service

CONTAINER

Service

CONTAINER

Service

CONTAINER

Page 53: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

CUSTOMER EXAMPLES

Page 54: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

FINANCIAL SERVICES: UNITED KINGDOM

SOLUTION:

SUCCESS:“We need to deliver products to market quicker than ever and be more responsive to market trends. We want to become the bank of the future.”

SIMON CASHMORE, HEAD OF PAAS MIDDLEWARE ENGINEERING, BARCLAYS

● With its new DevOps approach and aPaaS environment, Barclays’ developers can work more efficiently to quickly release updates and features.

● Self-service capabilities have cut provisioning times from weeks to hours and freed up IT staff to work on new, valuable projects instead of routine tasks

Red Hat 2017 Innovation Award Winner

Page 55: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

Red Hat OpenShift Container PlatformRed Hat 3scale API Management PlatformRed Hat JBoss Enterprise Application Platform

Red Hat JBoss FuseRed Hat Gluster StorageRed Hat OpenShift Dedicated

TRANSPORTATION/EMEA

SOLUTIONMigrated several of its IT systems to the cloud to become more flexible, secure, and efficient.

WHY RED HATWanted to select open source software that was backed by support from a trusted vendor. Created API foundation for seamless handoff between the airport and its partners.

RESULTS● Achieved quick development and deployment ● Gained support for more agile processes through self service capabilities ● Made flight, baggage, reservation, and other data available throughout the airport

and to all partners

CHALLENGETo become best digital airport and improve passenger experience

PRODUCTS & SERVICES

Source: Red Hat case study, Amsterdam Airport Schiphol builds agile cloud with Red Hat, August, 2017.

Launched a new cloud platform in

10 days and cut development time for new services and APIs

by

50% Red Hat SatelliteRed Hat Consulting

Page 56: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

Red Hat 3scale API Management

Page 57: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

RED HAT 3scale API MANAGEMENT PLATFORMEnabling API first

API visibility & control enterprise wide

Security, rate limits, analytics, API keys,

developer portal

Manage internal and external APIs

Transform internal IT into “API first” approach

Empower teams to deliver their own APIs

Provide global visibility and a uniform approach

Page 58: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

GARTNER API MANAGEMENT MQ

Gartner recognized Red Hat as a LEADER in the Magic Quadrant for Full Life Cycle API Management, Apr 2018

Page 59: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

AWARD WINNING INNOVATIONS

❏ Leader in Gartner Magic Quadrant for Full Lifecycle API Management (2016, 2018)

❏ CODiE 2017 SIIA award: Best API Management Platform

❏ 2017 API World award: Best API Management Platform

Page 60: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security
Page 61: Cloud native and microservices architecture · 2019-06-06 · Cloud native and microservices architecture 1 Andrzej Kowalczyk Senior Solutions Architect. ... Monitoring Log Mgmt Security

CONFIDENTIAL Designator

linkedin.com/company/red-hat

youtube.com/user/RedHatVideos

facebook.com/redhatinc

twitter.com/RedHat

61

Red Hat is the world’s leading provider of enterprise

open source software solutions. Award-winning

support, training, and consulting services make Red

Hat a trusted adviser to the Fortune 500.

Thank you