-
Notifications
You must be signed in to change notification settings - Fork 4
/
whisper.yaml
182 lines (169 loc) · 4.78 KB
/
whisper.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
Resources:
MyVPC:
Type: AWS::EC2::VPC
Properties:
CidrBlock: "10.0.0.0/16"
Tags:
- Key: Name
Value: "My VPC"
MyInternetGateway:
Type: AWS::EC2::InternetGateway
Properties:
Tags:
- Key: Name
Value: "My IGW"
MyVPCGatewayAttachment:
Type: AWS::EC2::VPCGatewayAttachment
Properties:
VpcId: !Ref MyVPC
InternetGatewayId: !Ref MyInternetGateway
MyPublicSubnet:
Type: AWS::EC2::Subnet
Properties:
CidrBlock: "10.0.1.0/24"
VpcId: !Ref MyVPC
AvailabilityZone: !Select [0, !GetAZs ""]
Tags:
- Key: Name
Value: "My Public Subnet"
MyRouteTable:
Type: AWS::EC2::RouteTable
Properties:
VpcId: !Ref MyVPC
Tags:
- Key: Name
Value: "My Route Table"
MyDefaultRoute:
Type: AWS::EC2::Route
DependsOn: MyVPCGatewayAttachment
Properties:
RouteTableId: !Ref MyRouteTable
DestinationCidrBlock: "0.0.0.0/0"
GatewayId: !Ref MyInternetGateway
MySubnetRouteTableAssociation:
Type: AWS::EC2::SubnetRouteTableAssociation
Properties:
SubnetId: !Ref MyPublicSubnet
RouteTableId: !Ref MyRouteTable
MySecurityGroup:
Type: AWS::EC2::SecurityGroup
Properties:
GroupName: "My Security Group"
GroupDescription: "My security group"
VpcId: !Ref MyVPC
SecurityGroupIngress:
- IpProtocol: tcp
FromPort: 22
ToPort: 22
CidrIp: 0.0.0.0/0
- IpProtocol: tcp
FromPort: 8501
ToPort: 8501
CidrIp: 0.0.0.0/0
MyInstanceRole:
Type: AWS::IAM::Role
Properties:
AssumeRolePolicyDocument:
Version: 2012-10-17
Statement:
- Effect: Allow
Principal:
Service: ec2.amazonaws.com
Action: sts:AssumeRole
ManagedPolicyArns:
- arn:aws:iam::aws:policy/AdministratorAccess
MyInstance:
Type: AWS::EC2::Instance
DeletionPolicy: Retain
Properties:
InstanceType: !Ref InstanceType
ImageId: !Ref InstanceAMI
BlockDeviceMappings:
- DeviceName: /dev/sda1
Ebs:
VolumeSize: 100
VolumeType: gp3
"Tags" : [
{"Key" : "Name", "Value" : "whisper"},
]
KeyName: !Ref KeyPairName
IamInstanceProfile: !Ref MyInstanceRole
NetworkInterfaces:
- DeviceIndex: 0
AssociatePublicIpAddress: true
SubnetId: !Ref MyPublicSubnet
GroupSet:
- !Ref MySecurityGroup
UserData:
'Fn::Base64': !Sub |
#!/bin/bash
sudo apt update
sudo apt install -y python3-pip nvidia-driver-525 ffmpeg git nvidia-cuda-toolkit
git clone https://github.com/superyhee/whisper-on-ec2-jumpstart /home/ubuntu/whisper
cd /home/ubuntu/whisper
pip3 install -r requirements.txt
# Setup environment
echo "HF_TOKEN=${HuggingFaceToken}" >> /home/ubuntu/whisper/.env
echo "------Install Finished ------"
# Add permissions to whisper directory
sudo chown -R ubuntu:ubuntu /home/ubuntu/whisper/
sudo chmod -R 755 /home/ubuntu/whisper/
# Create systemd service
sudo tee /etc/systemd/system/whisper.service > /dev/null <<EOF
[Unit]
Description=Whisper Service
After=network.target
[Service]
User=ubuntu
ExecStart=streamlit run /home/ubuntu/whisper/ui.py
WorkingDirectory=/home/ubuntu/whisper
Restart=always
[Install]
WantedBy=multi-user.target
EOF
# Reload systemd and enable service
sudo systemctl daemon-reload
sudo systemctl enable whisper.service
# Start the service
sudo systemctl start whisper.service
sudo reboot
MyEIP:
Type: AWS::EC2::EIP
MyEIPAssociation:
Type: AWS::EC2::EIPAssociation
Properties:
InstanceId: !Ref MyInstance
EIP: !Ref MyEIP
Outputs:
ElasticIP:
Description: The Elastic IP address
Value: !Ref MyEIP
Export:
Name: MyElasticIP
Parameters:
InstanceAMI:
Type: AWS::EC2::Image::Id
Description: ID of the AMI to use for the EC2 instance
KeyPairName:
Type: AWS::EC2::KeyPair::KeyName
Description: Name of the SSH key pair to use for the EC2 instance
InstanceType:
Type: String
Description: EC2 instance type
Default: g4dn.xlarge
AllowedValues:
- g4dn.xlarge
- g4dn.2xlarge
- g4dn.4xlarge
- g4dn.8xlarge
- g4dn.12xlarge
- g4dn.16xlarge
- g5.xlarge
- g5.2xlarge
- g5.4xlarge
- g5.8xlarge
- g5.12xlarge
- g5.24xlarge
HuggingFaceToken:
Type: String
Description: Hugging Face token for authentication