mirror of
				https://github.com/sickcodes/Docker-OSX.git
				synced 2025-10-25 22:45:53 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			204 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			204 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| # This is a YAML-formatted file.
 | |
| # Declare variables to be passed into your templates.
 | |
| 
 | |
| replicaCount: 1
 | |
| 
 | |
| image:
 | |
|   repository: sickcodes/docker-osx-vnc
 | |
|   tag: latest
 | |
|   pullPolicy: IfNotPresent
 | |
|   userName: ubuntu
 | |
| 
 | |
| # Please note, this must be a directory name within `/system_image` mounted at the bottom in extraVolumeMounts
 | |
| serverName: server
 | |
| 
 | |
| macos:
 | |
|   # add kexts to EFI/OC/kexts and update config.plist
 | |
|   #  make sure your kexts are in kexts.path
 | |
|   kexts:
 | |
|     add: false
 | |
|     path: /system_image/kexts
 | |
|     kextsToAdd: {}
 | |
|     # - name: BrcmBluetoothInjector.kext
 | |
|     #   executablePath: Contents/MacOS/BrcmBluetoothInjector
 | |
|     #   plistPath: Contents/Info.plist
 | |
|     # - name: BrcmFirmwareData.kext
 | |
|     #   executablePath: Contents/MacOS/BrcmFirmwareData
 | |
|     #   plistPath: Contents/Info.plist
 | |
|     # - name: BrcmPatchRAM3.kext
 | |
|     #   executablePath: Contents/MacOS/BrcmPatchRAM3
 | |
|     #   plistPath: Contents/Info.plist
 | |
|   # SMBIOS settings
 | |
|   configPlist:
 | |
|     SystemProductName: iMacPro1,1
 | |
|     MLB: D25338500GUF8YLJA
 | |
|     SystemSerialNumber: D25LF7ZEF8JC
 | |
|     SystemUUID: 139C94D6-A533-47D2-874F-D365BFD8B047
 | |
|     bootArgs: '-v keepsyms=1 tlbto_us=0 vti=9 -wegoff agdpmod=pikera'
 | |
|   openCore:
 | |
|     # Rebuild OpenCore.qcow2: this can be disabled if none of the above parameters in kexts, configPlist changes, and changing the
 | |
|     #  resolution are not desired, utilizing gpu passthrough and a few other things. Disabling is not recommended
 | |
|     rebuild: true
 | |
|     boot:
 | |
|       # set to zero to have OpenCore stay at boot menu
 | |
|       timeout: 0
 | |
|   installerSettings:
 | |
|     # if using more than one deployment, a write lock will be put on the system installer dmg, so this will need to be disabled
 | |
|     #  for other pods
 | |
|     version: 10.15.7
 | |
|     path: /system_image/installers
 | |
| 
 | |
| # This section defines QEMU and virtlo parameters
 | |
| #
 | |
| # Note:
 | |
| #  *) Increase downloadDelay if the pod gets killed for readiness/liveliness check. The first time the pod is started,
 | |
| #       it will download the BaseSystem image and create a data partition to install the OS. If this value is really long,
 | |
| #       the pod will take very long to allow VNC connections if it is rebooted/killed.
 | |
| #  *) Big Sur (11.X) is currently broken, as it seems Apple reworked the packaging so that will have to be something fixed in
 | |
| #       https://github.com/kholia/OSX-KVM/blob/master/fetch-macOS-v2.py
 | |
| #  *) VNC and IOMMU GPU passthrough do not play together well. Disable one if using the other. This is a limitation of QEMU
 | |
| #       unfortunately, so this means VNC from macOS will have to be used to view the VM when not using a physical GPU.
 | |
| #  *) If using GPU passthrough, it is recommended to configure it first, as the installer will take way longer (several hours)
 | |
| #       to install macOS with a software GPU configured.
 | |
| #
 | |
| qemu:
 | |
|   cpu: Penryn,kvm=on,vendor=GenuineIntel,+invtsc,vmware-cpuid-freq=on,+pcid,+ssse3,+sse4.2,+popcnt,+avx,+avx2,+aes,+xsave,+xsaveopt,check
 | |
|   softwareGpu: vmware
 | |
|   hardwareGpu:
 | |
|     # when enabled, qemu.softwareGpu will be disabled automatically. disabling this will rely on softwareGpu instead
 | |
|     enabled: false
 | |
|     hardwareId: 09:00
 | |
|     # slot can be found with `lspci -v -s <hardware-id>`
 | |
|     slot: 05
 | |
|     # vfioGroup can be found with lsgroup.sh:
 | |
|     #  https://github.com/kholia/OSX-KVM/blob/master/scripts/lsgroup.sh
 | |
|     vfioGroup: 50
 | |
|     # leave romfile blank if not using one to disable
 | |
|     romfile: /system_image/vbios/Sapphire.RX480.8192.160603.rom
 | |
|   systemInstaller:
 | |
|     # if using more than one deployment, a write lock will be put on the system installer dmg, so this will need to be disabled
 | |
|     #  for other pods
 | |
|     enabled: false
 | |
|     downloadDelay: 15
 | |
|     # can be `writethrough`, `writeback`, or `none`
 | |
|     cache: none
 | |
|     # can be `native` or `threads`
 | |
|     io: threads
 | |
|   systemDisk:
 | |
|     size: 128G
 | |
|     # can be `writethrough`, `writeback`, or `none`
 | |
|     cache: writeback
 | |
|     # can be `native` or `threads`
 | |
|     io: threads
 | |
|   audio:
 | |
|     # this enables onboard audio, hdmi audio is handled with qemu.hardwareGpu
 | |
|     enabled: false
 | |
|     driver: alsa
 | |
|   netdev:
 | |
|     extraPortForwarding: hostfwd=tcp::5901-:5900
 | |
|   # for usb, pass host adapters like such:
 | |
|   # usb:
 | |
|   #   - vendorId: 0a5c
 | |
|   #     productId: 21e8
 | |
|   #
 | |
|   # please use lsgroup.sh to find your host ids:
 | |
|   #  https://github.com/kholia/OSX-KVM/blob/master/scripts/lsgroup.sh
 | |
|   #
 | |
|   # for usb, may need to fix permissions:
 | |
|   #   sudo chmod 666 /dev/bus/usb/<bus>/<device>
 | |
|   #
 | |
|   # if need to add a usb controller via vfio-pci, use qemu.extraArgs
 | |
|   #
 | |
|   usb: {}
 | |
|   # use the following formatting
 | |
|   # extraArgs:
 | |
|   # - -parallel none
 | |
|   # - -boot order=dc
 | |
|   extraArgs: {}
 | |
| 
 | |
| # Password for accessing vm over vnc
 | |
| vnc:
 | |
|   enabled: true
 | |
|   resolution: 1920x1080
 | |
|   password: a5aeQbaPd4$jR80Q43
 | |
| 
 | |
| nameOverride: ""
 | |
| fullnameOverride: ""
 | |
| 
 | |
| service:
 | |
|   type: LoadBalancer
 | |
|   ip: 192.168.1.10
 | |
|   targetPort: 50922
 | |
|   port: 10022
 | |
|   extraPorts:
 | |
|   - port: 5901
 | |
|     targetPort: 5901
 | |
|     protocol: TCP
 | |
|     name: os-level-vnc
 | |
| 
 | |
| ingress:
 | |
|   enabled: false
 | |
|   annotations: {}
 | |
|     # kubernetes.io/ingress.class: nginx
 | |
|   # kubernetes.io/tls-acme: "true"
 | |
|   paths:
 | |
|   - /
 | |
|   hosts:
 | |
|   - docker-osx.local
 | |
|   tls: []
 | |
|   #  - secretName: chart-example-tls
 | |
|   #    hosts:
 | |
|   #      - chart-example.local
 | |
| 
 | |
| # Note: Resources can vary dramatically depending on disk caching and software GPU rendering. With disk
 | |
| #  caching and software rendering up to x5 the cpu and x9 memory can be consumed. With disk cache off
 | |
| #  and GPU passthrough enabled up to x3 the cpu and x1.5 memory can be consumed. Therefore, these settings
 | |
| #  really depend on hardware and configuration choices. Note, these values used a 1080p video resolution
 | |
| #  as well. 
 | |
| #
 | |
| #  Warning: do not perform unit conversion on cpu and memory requests, as these units
 | |
| #   are tied qemu and virtio settings. Also, only use intergers for cpu requests.
 | |
| resources:
 | |
|   limits:
 | |
|    cpu: 15
 | |
|    memory: 32768Mi
 | |
|   requests:
 | |
|    cpu: 4
 | |
|    memory: 16384Mi
 | |
| 
 | |
| nodeSelector: {}
 | |
| 
 | |
| tolerations: []
 | |
| 
 | |
| affinity: {}
 | |
| 
 | |
| persistence:
 | |
|   data:
 | |
|     enabled: false
 | |
|     ## configuration data Persistent Volume Storage Class
 | |
|     ## If defined, storageClassName: <storageClass>
 | |
|     ## If set to "-", storageClassName: "", which disables dynamic provisioning
 | |
|     ## If undefined (the default) or set to null, no storageClassName spec is
 | |
|     ##   set, choosing the default provisioner.  (gp2 on AWS, standard on
 | |
|     ##   GKE, AWS & OpenStack)
 | |
|     ##
 | |
|     # storageClass: "-"
 | |
|     ##
 | |
|     ## If you want to reuse an existing claim, you can pass the name of the PVC using
 | |
|     ## the existingClaim variable
 | |
|     existingClaim: docker-osx
 | |
|     accessMode: ReadWriteOnce
 | |
|     size: 5Gi
 | |
| 
 | |
| # Any extra volumes to define for the pod
 | |
| extraVolumes:
 | |
|   - name: data
 | |
|     hostPath:
 | |
|       path: /mnt/data/default/docker_osx/
 | |
|       type: DirectoryOrCreate
 | |
| 
 | |
| # Any extra volume mounts to define for the containers
 | |
| extraVolumeMounts:
 | |
|   - name: data
 | |
|     mountPath: /system_image
 |